Можно ли использовать объединенную таблицу в качестве основы для модели?

== сравнивает ссылки на объекты.

.equals() сравнивает значения String.

Иногда == дает иллюзии сравнения значений String, как в следующих случаях:

String a="Test";
String b="Test";
if(a==b) ===> true

Это связано с тем, что при создании любого строкового литерала JVM сначала ищет этот литерал в пуле строк, и если он найдет совпадение, эта же ссылка будет передана новой String. Из-за этого получаем:

(a == b) ===> true

                       String Pool
     b -----------------> "test" <-----------------a

Однако == не выполняется в следующем случае:

String a="test";
String b=new String("test");
if (a==b) ===> false

В этом случае для new String("test") оператор new String будет создан в куче, и эта ссылка будет указана на b, поэтому b будет дана ссылка на кучу, а не на String pool.

Теперь a указывает на String в пуле String, а b указывает на String в куче. Из-за этого мы получаем:

, если (a == b) ===> false.

                String Pool
     "test" <-------------------- a

                   Heap
     "test" <-------------------- b

Пока .equals() всегда сравнивает значение String, поэтому дает true в обоих случаях:

String a="Test";
String b="Test";
if(a.equals(b)) ===> true

String a="test";
String b=new String("test");
if(a.equals(b)) ===> true

Таким образом, использование .equals() всегда лучше.

0
задан Ig Norand 17 January 2019 в 10:01
поделиться

1 ответ

У вас есть возможность создать представление базы данных, которое инкапсулирует обе таблицы и переименовывает столбцы в соглашения rails?

например.

create view id_card_requests as 
select 
  existing_column as desired_rails_column_name,
  ... 
from id_cards 
join id_card_requests on <whatever the join is>

Затем вы можете сделать модель рельсов IdCardRequests, которая будет работать как обычно. Вы можете сделать один из столбцов первичным ключом в представлении или указать модели использовать один из столбцов с помощью self.primary_key = :my_key_column

0
ответ дан Matt 17 January 2019 в 10:01
поделиться
Другие вопросы по тегам:

Похожие вопросы: