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)
);
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,993评论 19 139
  • SQL SELECT 语句 一、查询SQL SELECT 语法 (1)SELECT 列名称 FROM 表名称 (2...
    有钱且幸福阅读 5,743评论 0 33
  • 学习web安全足足有一个半月有余,之前学的是前端,也会一点python。。好吧差不多忘了。常规工具算是熟悉基本...
    一叶红尘哦哟阅读 3,409评论 4 92
  • SQL语言基础 本章,我们将会重点探讨SQL语言基础,学习用SQL进行数据库的基本数据查询操作。另外请注意本章的S...
    厲铆兄阅读 5,359评论 2 46
  • 亲眼见证了身边的女子: 从女孩,到恋爱,结婚,怀孕,生子,所经历的苦痛。 胎儿在成长,女人的身体在变化着, 肚皮长...
    LittleWang小王子阅读 172评论 1 1