powered by simpleCommunicator - 2.0.53     © 2025 Programmizd 02
Форумы / PostgreSQL [игнор отключен] [закрыт для гостей] / Как добавить констрэйнт на NULL ?
5 сообщений из 5, страница 1 из 1
Как добавить констрэйнт на NULL ?
    #39898984
комит
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Гость
Доброе утро.

Есть таблица:

Код: sql
1.
CREATE TABLE text1(id int,value text);




Надо сделать констрэйнт, который не позволяет вставить дубли и при этом учитывает NULL по первому столбцу.


Т.е. такой:

Код: sql
1.
ALTER text1 ADD CONSTRAINT text1_con UNIQUE (id,, value);



Позволяет вставить (NULL,'some_text') сколько угодно раз.



А

Код: sql
1.
ALTER text1 ADD CONSTRAINT text1_con UNIQUE (COALESCE(id,0), value);



Вызывает ошибку:
LINE 1: ALTER text1 ADD CONSTRAINT text1_con UNIQUE (COALESCE(id,0),...



Уникальный индекс с COALESCE решает проблему, но интересует как можно сделать именно CONSTRAINT с COALESCE?
...
Рейтинг: 0 / 0
Как добавить констрэйнт на NULL ?
    #39898990
Melkij
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
комит
сделать именно CONSTRAINT

Никак.

А нужен ли именно CONSTRAINT (зачем?) или уникального индекса достаточно? Уникальный индекс по функциям может быть.
...
Рейтинг: 0 / 0
Как добавить констрэйнт на NULL ?
    #39898991
комит
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Гость
Melkij
комит
сделать именно CONSTRAINT

Никак.

А нужен ли именно CONSTRAINT (зачем?) или уникального индекса достаточно? Уникальный индекс по функциям может быть.




Хотелось бы именно констрэйнт, он красивее.
...
Рейтинг: 0 / 0
Как добавить констрэйнт на NULL ?
    #39899010
alex-ls
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
комит
...
Хотелось бы именно констрэйнт, он красивее .

жениться на нем будете?
...
Рейтинг: 0 / 0
Как добавить констрэйнт на NULL ?
    #39899040
комит
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Гость
alex-ls
комит
...
Хотелось бы именно констрэйнт, он красивее .

жениться на нем будете?


Нет, я не москвич.
...
Рейтинг: 0 / 0
5 сообщений из 5, страница 1 из 1
Форумы / PostgreSQL [игнор отключен] [закрыт для гостей] / Как добавить констрэйнт на NULL ?
Целевая тема:
Создать новую тему:
Автор:
Закрыть
Цитировать
Найденые пользователи ...
Разблокировать пользователей ...
Читали форум (0):
Пользователи онлайн (0):
x
x
Закрыть


Просмотр
0 / 0
Close
Debug Console [Select Text]