Mysql
 sql >> Baza danych >  >> RDS >> Mysql

Railsy ActiveRecord obsługują kolumnę id, która nie jest kluczem podstawowym

Odpowiedź @cschroed nie działała dla mnie w najnowszych Railsach (v4.2). Zagłębiając się w kod źródłowy Railsów, okazuje się, że read_attribute użyje również wartości klucza podstawowego, jeśli przekazany klucz jest równy „id”:

  ID = 'id'.freeze

  # Returns the value of the attribute identified by <tt>attr_name</tt> after
  # it has been typecast (for example, "2004-12-12" in a date column is cast
  # to a date object, like Date.new(2004, 12, 12)).
  def read_attribute(attr_name, &block)
    name = attr_name.to_s
    name = self.class.primary_key if name == ID
    _read_attribute(name, &block)
  end

https://github .com/rails/rails/blob/4-2-stable/activerecord/lib/active_record/attribute_methods/read.rb

Ponieważ metoda [] używa read_attribute , to już nie działa.

Zauważyłem, że zamiast tego działa bezpośrednie czytanie z hash atrybutów:

# LegacyModel class
def other_id
  @attributes.fetch_value('id')
end

Umożliwiło to ominięcie read_attribute naśladując _read_attribute .



  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Jak zarządzać uprawnieniami za pomocą ról w MySQL

  2. MySQL ORDER BY [niestandardowa wartość pola SET]

  3. Sumowanie zakresu dat bez zliczania nakładania się w mysql

  4. Znajdowanie nadchodzących urodzin za pomocą jOOQ

  5. Pobierz ścieżkę drzewa w tabeli MySQL