Как сделать внешний ключ, который может быть двумя разными типами данных, без использования CREATE CAST? [Дубликат]

Многие объяснения уже присутствуют, чтобы объяснить, как это происходит и как это исправить, но вы также должны следовать рекомендациям, чтобы избежать NullPointerException вообще.

См. также: A хороший список лучших практик

Я бы добавил, очень важно, хорошо использовать модификатор final. Использование "окончательной" модификатор, когда это применимо в Java

Сводка:

  1. Используйте модификатор final для обеспечения хорошей инициализации.
  2. Избегайте возврата null в методы, например, при возврате пустых коллекций.
  3. Использовать аннотации @NotNull и @Nullable
  4. Быстрое завершение работы и использование утверждений, чтобы избежать распространения нулевых объектов через все приложение, когда они не должен быть пустым.
  5. Сначала используйте значения с известным объектом: if("knownObject".equals(unknownObject)
  6. Предпочитают valueOf() поверх toString ().
  7. Используйте null safe StringUtils StringUtils.isEmpty(null).

3
задан Osha Wott 7 May 2015 в 22:14
поделиться

1 ответ

Вы можете создать два внешних ключа с контрольным ограничением, в котором указано, что один из них пуст:

create table alien (id int primary key);
create table monster (id int primary key);
create table trophy (id int primary key,
    alien_id int references alien(id),
    monster_id int references monster(id),
    check (alien_id is null <> monster_id is null)
);
1
ответ дан Andomar 18 August 2018 в 03:00
поделиться
  • 1
    Это то, что я делал сейчас, но мне было интересно, есть ли способ иметь одну ссылку на поле для двух разных таблиц. – Osha Wott 8 May 2015 в 14:18
Другие вопросы по тегам:

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