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)
);