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;

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(
       ID   INT              NOT NULL,
       NAME VARCHAR (20)     NOT NULL,
       AGE  INT              NOT NULL,
       ADDRESS  CHAR (25) ,
       SALARY   DECIMAL (18, 2),       
       PRIMARY KEY (ID)
);
ORDERS 表:

CREATE TABLE ORDERS (
       ID          INT        NOT NULL,
       DATE        DATETIME, 
       CUSTOMER_ID INT references CUSTOMERS(ID),
       AMOUNT     double,
       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(
       ID   INT              NOT NULL,
       NAME VARCHAR (20)     NOT NULL,
       AGE  INT              NOT NULL UNIQUE  CHECK (AGE >= 18), 
       ADDRESS  CHAR (25)  ,
       SALARY   DECIMAL (18, 2) DEFAULT 5000.00,       
       PRIMARY KEY (ID)
);

你可能感兴趣的:(SQL NULL 约束)