如何解决尝试在H2数据库中设置具有DEFAULT NULL的UNIQUE约束时出错
我想创建一个带有UNIQUE约束且DEFAULT NULL的列的表,请参见下面的代码片段中的notes_id列。在Postgres中可以使用,但在H2中则不能使用,但是根据文档,它应该可以使用(http://www.h2database.com/html/grammar.html#column_definition)。
这是DDL脚本:
for df in dfs:
print (df)
Футбол. Сборные. Лига наций УЕФА. Лига A ...
Событие ... Unnamed: 19_level_1
0 Матч! Футбол 104/09 19:45Италия - Босния ... NaN
1 Матч ТВ04/09 19:45Нидерланды - Польша ... NaN
2 Матч ТВ05/09 17:00Исландия - Англия ... NaN
3 Матч! Футбол 305/09 19:45Дания - Бельгия ... NaN
4 Матч ТВ05/09 19:45Португалия - Хорватия ... NaN
5 Матч! Футбол 205/09 19:45Швеция - Франция ... NaN
6 Матч ТВ06/09 19:45Испания - Украина ... NaN
7 Матч! Футбол 106/09 19:45Швейцария - Германия ... NaN
8 07/09 19:45Босния - Польша ... NaN
9 Матч ТВ07/09 19:45Нидерланды - Италия ... NaN
10 Матч! Футбол 308/09 19:45Бельгия - Исландия ... NaN
11 08/09 19:45Дания - Англия ... NaN
12 Матч ТВ08/09 19:45Франция - Хорватия ... NaN
13 08/09 19:45Швеция - Португалия ... NaN
[14 rows x 20 columns]
Футбол. Сборные. Лига наций УЕФА. Лига A. Статистические данные ...
Событие ... Unnamed: 19_level_1
0 04/09 19:45Италия % вл мяч - Босния % вл мяч ... NaN
1 04/09 19:45Италия угл - Босния угл ... NaN
2 04/09 19:45Италия ж/к - Босния ж/к ... NaN
3 04/09 19:45Италия уд в ст - Босния уд в ст ... NaN
4 04/09 19:45Италия фолы - Босния фолы ... NaN
5 04/09 19:45Италия офс - Босния офс ... NaN
6 04/09 19:45Италия уд по воротам - Босния уд по... ... NaN
7 04/09 19:45Италия ауты - Босния ауты ... NaN
8 04/09 19:45Италия сэйвы - Босния сэйвы ... NaN
9 04/09 19:45Нидерланды % вл мяч - Польша % вл мяч ... NaN
10 04/09 19:45Нидерланды угл - Польша угл ... NaN
11 04/09 19:45Нидерланды ж/к - Польша ж/к ... NaN
12 04/09 19:45Нидерланды уд в ст - Польша уд в ст ... NaN
13 04/09 19:45Нидерланды фолы - Польша фолы ... NaN
14 04/09 19:45Нидерланды офс - Польша офс ... NaN
15 04/09 19:45Нидерланды уд по воротам - Польша у... ... NaN
16 04/09 19:45Нидерланды ауты - Польша ауты ... NaN
17 04/09 19:45Нидерланды сэйвы - Польша сэйвы ... NaN
18 05/09 17:00Исландия ж/к - Англия ж/к ... NaN
19 05/09 17:00Исландия угл - Англия угл ... NaN
[20 rows x 20 columns]
Футбол. Сборные. Лига наций УЕФА. Лига B ...
Событие ... Unnamed: 19_level_1
0 Матч! Футбол 204/09 19:45Норвегия - Австрия ... NaN
1 04/09 19:45Румыния - Сев Ирландия ... NaN
2 Матч! Футбол 304/09 19:45Словакия - Чехия ... NaN
3 04/09 19:45Шотландия - Израиль ... NaN
4 Матч! Футбол 106/09 14:00Уэльс - Болгария ... NaN
5 Первый06/09 17:00Венгрия - Россия ... NaN
6 Матч ТВ06/09 17:00Ирландия - Финляндия ... NaN
7 Матч! Футбол 206/09 19:45Сербия - Турция ... NaN
8 07/09 19:45Австрия - Румыния ... NaN
9 07/09 19:45Израиль - Словакия ... NaN
10 07/09 19:45Сев Ирландия - Норвегия ... NaN
11 07/09 19:45Чехия - Шотландия ... NaN
[12 rows x 20 columns]
Футбол. Сборные. Лига наций УЕФА. Лига B. Статистические данные ...
Событие ... Unnamed: 19_level_1
0 04/09 19:45Норвегия % вл мяч - Австрия % вл мяч ... NaN
1 04/09 19:45Норвегия ауты - Австрия ауты ... NaN
2 04/09 19:45Норвегия ж/к - Австрия ж/к ... NaN
[3 rows x 20 columns]
这是我得到的错误:
CREATE TABLE highlights (
id bigserial PRIMARY KEY NOT NULL,user_ref_id uuid,body varchar(10000) DEFAULT NULL,annotation_id integer UNIQUE DEFAULT NULL
);
根据此处的此线程,这应该是可能的:https://groups.google.com/g/h2-database/c/HrYKGMN2LPQ?pli=1
H2已经在唯一约束中支持NULL。
我想念什么?
解决方法
-
您不能在列定义的中间指定列约束(
UNIQUE
或任何其他约束),此类约束只能写在列定义的末尾:annotation_id integer DEFAULT NULL UNIQUE
。 -
DEFAULT NULL
是一个无意义的子句,如果未指定其他值,则无论是否有此子句,所有可空列都将分配给NULL
。可以删除此子句。仅当您要将其他值指定为默认值时,才需要使用DEFAULT
子句。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。