SQL|SQL NULL 约束

1.SQL NULL
是用来代表缺失值的术语。在表中的NULL值是显示为空白字段的值。
NULL值字段是一个记录创建过程中已经被保留为空。
必须使用IS NULL或IS NOT NULL运算符来检查(或比较)一个NULL值。

SQL> SELECT ID, NAME, AGE, ADDRESS, SALARY FROM CUSTOMERS WHERE SALARY IS NOT NULL;

2.约束
NOT NULL 约束: 确保列不能有NULL值。
ALTER TABLE CUSTOMERS MODIFY SALARY DECIMAL (18, 2) NOT NULL;

【SQL|SQL NULL 约束】DEFAULT约束: 提供未指定时为列的默认值。
ALTER TABLE CUSTOMERS MODIFY SALARY DECIMAL (18, 2) DEFAULT 5000.00; #删除默认约束 ALTER TABLE CUSTOMERS ALTER COLUMN SALARY DROP DEFAULT;

UNIQUE约束: 确保了在一列中的所有的值是不同(唯一)的。
ALTER TABLE CUSTOMERS MODIFY AGE INT NOT NULL UNIQUE; ALTER TABLE CUSTOMERS ADD CONSTRAINT myUniqueConstraint UNIQUE(AGE, SALARY); #删除 ALTER TABLE CUSTOMERS DROP CONSTRAINT myUniqueConstraint; #mysql删除 ALTER TABLE CUSTOMERS DROP INDEX myUniqueConstraint;

PRIMARY Key(主键) : 唯一标识数据库表中的每一行/记录。
ALTER TABLE CUSTOMER ADD PRIMARY KEY (ID); ALTER TABLE CUSTOMERS ADD CONSTRAINT PK_CUSTID PRIMARY KEY (ID, NAME); #删除 ALTER TABLE CUSTOMERS DROP PRIMARY KEY ;

FOREIGN Key(外键): 唯一标识任何其他数据库表中的行/记录。
CUSTOMERS 表:CREATE TABLE CUSTOMERS( IDINTNOT NULL, NAME VARCHAR (20)NOT NULL, AGEINTNOT NULL, ADDRESSCHAR (25) , SALARYDECIMAL (18, 2), PRIMARY KEY (ID) ); ORDERS 表:CREATE TABLE ORDERS ( IDINTNOT NULL, DATEDATETIME, CUSTOMER_ID INT references CUSTOMERS(ID), AMOUNTdouble, PRIMARY KEY (ID) ); #如果外键没设置 ALTER TABLE ORDERS ADD FOREIGN KEY (Customer_ID) REFERENCES CUSTOMERS (ID); #删除 ALTER TABLE ORDERS DROP FOREIGN KEY;

CHECK约束: CHECK约束可以确保列中的所有值满足一定的条件。
添加check约束
ALTER TABLE CUSTOMERS MODIFY AGE INT NOT NULL CHECK (AGE >= 18 ); #也可以 ALTER TABLE CUSTOMERS ADD CONSTRAINT myCheckConstraint CHECK(AGE >= 18); #删除约束 ALTER TABLE CUSTOMERS DROP CONSTRAINT myCheckConstraint;

INDEX索引: 使用非常快速地创建和检索数据库中的数据。
创建删除索引
CREATE INDEX index_name ON table_name ( column1, column2.....); ALTER TABLE CUSTOMERS DROP INDEX idx_age;

CREATE TABLE CUSTOMERS( IDINTNOT NULL, NAME VARCHAR (20)NOT NULL, AGEINTNOT NULL UNIQUECHECK (AGE >= 18), ADDRESSCHAR (25), SALARYDECIMAL (18, 2) DEFAULT 5000.00, PRIMARY KEY (ID) );

    推荐阅读