SQL约束

约束的概念和分类

        1.约束的概念

                约束是作用于表中列上的规则,用于限制加入表的数据

                约束的存在保证了数据库中数据的正确性、有效性和完整性

        2.约束的分类

约束名称描述关键字
非空约束保证列中所有数据不能有null值NOT NULL
唯一约束保证列中所有数据各不相同UNIQUE
主键约束主键是一行数据的唯一标识、要求非空唯一PRIMARY KEY
检查约束保证列中的值满足某一条件CHECK
默认约束保存数据时,未指定值则采用默认值DEFAULT
外键约束外键用来让两个表的数据之间建立链接,保证数据的一致性和完整性FOREIGH KEY

                        Tips:MySQL不支持检查约束

                      例如:

                                CREATE TABLE emp(
                                    id INT  PRIMARY KEY auto_increment, -- 员工id,主键且自增长
                                    ename VARCHAR(50) NOT NULL UNIQUE,

                                        -- 员工姓名,非空并且唯一
                                    joindate DATE NOT NULL, -- 入职日期,非空
                                    salary DOUBLE(7,2) NOT NULL, -- 工资,非空
                                    bonus DOUBLE(7,2) DEFAULT 0 -- 奖金,如果奖金没有默认为0
                                );

 外键约束

        1.概念

                外键用来让两个表的数据之间建立链接,保证数据的一致性和完整性

        2.语法

                (1)添加约束

                -- 创建表时添加外键约束

                CREATE TABLE 表名(

                        列名 数据类型,

                        ...

                        [CONSTRAINT] [外键名称] FOREIGH KEY(外键列名) REFERENCES

                主表(主表列名)

                ); 

                例如:

                 -- 部门表
                CREATE TABLE dept(
                    id INT PRIMARY KEY auto_increment,
                    dep_name VARCHAR(20),
                    addr VARCHAR(20)
                );
                -- 员工表
                CREATE TABLE emp(
                    id int PRIMARY KEY auto_increment,
                    name VARCHAR(20),
                    age int,
                    dep_id int,
    
                    -- 添加外键 dep_id,关联 dept表的id主键
                    CONSTRAINT fk_emp_dept FOREIGN KEY(dep_id) REFERENCES dept(id)
                );

                 -- 建完表后添加外键约束

                ALTER TABLE 表名 ADD CONSTRAINT 外键名称 FOREIGN KEY (外键字段

                名称) REFERENCES 主表名称(主表列名称);

                例如:

                ALTER TABLE emp ADD CONSTRAINT fk_emp_dept FOREIGN KEY(dep_id)                 REFERENCES dept(id);

                (2)删除约束 

                ALTER TABLE 表名 DROP FOREIGH KEY 外键名称; 

                例如:

                ALTER TABLE emp DROP FOREIGN KEY fk_emp_dept;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值