![](/img/trans.png)
[英]Oracle SQLDeveloper: How to use the 'Filter' toolbar item to query by date?
[英]How to use CONSTRAINT CHECK in SQLDEVELOPER on a specific DATE?
我試圖在列Nr_AnoLetivo
上設置一個CONSTRAINT,該列是一個DATE,它只能是NOT NULL並且大於2000年。
我一直在嘗試:
CREATE TABLE Classe(
Cd_Classe NUMBER(8),
Nr_AnoLetivo NUMBER(4) CONSTRAINT CLASSE_NR_ANOLETIVO_NN NOT NULL,
Cd_Escola NUMBER(5),
Cd_Grau NUMBER(2),
Nr_Serie NUMBER(2) CONSTRAINT CLASSE_NR_SERIE_NN NOT NULL,
Sg_Turma VARCHAR2(2) CONSTRAINT CLASSE_SG_TURMA_NN NOT NULL,
Cd_Periodo NUMBER(2),
CONSTRAINT CLASSE_CD_CLASSE_PK PRIMARY KEY (CD_CLASSE),
CONSTRAINT CLASSE_NR_ANOLETIVO_CK CHECK (NR_ANOLETIVO IN DATE ('2000/01/01')),
CONSTRAINT ESCOLA_CD_ESCOLA_FK FOREIGN KEY (CD_ESCOLA) REFERENCES Escola (CD_ESCOLA),
CONSTRAINT GRAU_CD_GRAU_FK FOREIGN KEY (CD_GRAU) REFERENCES Grau (CD_GRAU),
CONSTRAINT PERIODO_CD_PERIODO_FK FOREIGN KEY (CD_PERIODO) REFERENCES Periodo (CD_PERIODO)
);
錯誤消息是:
- 00000-“缺少表達式”
有什么告訴我這個錯誤是由DATE行產生的,我不明白為什么。
誰能說出這是為什么呢?
你理解錯了。
如果您將NR_ANOLETIVO
列聲明為NUMBER(4)
,則似乎只希望年份在該列中(例如1957、1998、2010等),而不是整個日期(例如16.09.2018(dd.mm.yyyy) ))。
因此,設置約束以檢查某個日期值是錯誤的-您應該檢查放入該列的值是否大於2000。類似這樣的內容(您的代碼已簡化):
SQL> create table classe
2 (cd_classe number(8) constraint pk_cla primary key,
3 --
4 nr_anoletivo number(4) constraint ch_nra_2k check (nr_anoletivo > 2000)
5 not null,
6 --
7 cd_grau number(2));
Table created.
SQL> insert into classe (cd_classe, nr_anoletivo, cd_grau) values (1, 1990, 23);
insert into classe (cd_classe, nr_anoletivo, cd_grau) values (1, 1990, 23)
*
ERROR at line 1:
ORA-02290: check constraint (SCOTT.CH_NRA_2K) violated
SQL> insert into classe (cd_classe, nr_anoletivo, cd_grau) values (2, 2018, 33);
1 row created.
SQL>
如果您真的想檢查完整日期,則應該修改數據類型列(至DATE
)以及約束:
SQL> create table classe
2 (cd_classe number(8) constraint pk_cla primary key,
3 --
4 nr_anoletivo date constraint ch_nra_2k check (nr_anoletivo > date '2000-01-01')
5 not null,
6 --
7 cd_grau number(2));
Table created.
SQL> insert into classe (cd_classe, nr_anoletivo, cd_grau) values (1, date '1990-12-25', 23);
insert into classe (cd_classe, nr_anoletivo, cd_grau) values (1, date '1990-12-25', 23)
*
ERROR at line 1:
ORA-02290: check constraint (SCOTT.CH_NRA_2K) violated
SQL> insert into classe (cd_classe, nr_anoletivo, cd_grau) values (2, date '2018-09-16', 33);
1 row created.
SQL>
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.