• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    数据库中的sql完整性约束语句解析

    完整性约束

      完整性约束是为了表的数据的正确性!如果数据不正确,那么一开始就不能添加到表中。

    1 主键

    当某一列添加了主键约束后,那么这一列的数据就不能重复出现。这样每行记录中其主键列的值就是这一行的唯一标识。例如学生的学号可以用来做唯一标识,而学生的姓名是不能做唯一标识的,因为学生姓名有可能同名。
    主键列的值不能为NULL,也不能重复!

      指定主键约束使用PRIMARY KEY关键字

    创建表:定义列时指定主键:

    CREATE TABLE stu(
             sid    CHAR(6) PRIMARY KEY,
             sname   VARCHAR(20),
             age      INT,
             gender  VARCHAR(10)
    );

    创建表:定义列之后独立指定主键:

    CREATE TABLE stu(
             sid    CHAR(6),
             sname   VARCHAR(20),
             age      INT,
             gender  VARCHAR(10),
             PRIMARY KEY(sid)
    ); 

    修改表时指定主键:

    ALTER TABLE stu
    ADD PRIMARY KEY(sid);

    删除主键(只是删除主键约束,而不会删除主键列):

    ALTER TABLE stu DROP PRIMARY KEY;

    2 主键自增长

    MySQL提供了主键自动增长的功能!当主键设置为自动增长后,在没有给出主键值时,主键的值会自动生成,而且是最大主键值+1,也就不会出现重复主键的可能了。

    创建表时设置主键自增长(主键必须是整型才可以自增长):

    CREATE TABLE stu(
             sid INT PRIMARY KEY AUTO_INCREMENT,
             sname   VARCHAR(20),
             age      INT,
             gender  VARCHAR(10)
    ); 

    修改表时设置主键自增长:

    ALTER TABLE stu CHANGE sid sid INT AUTO_INCREMENT;

    修改表时删除主键自增长:

    ALTER TABLE stu CHANGE sid sid INT;

    3 非空

    指定非空约束的列不能没有值,也就是说在插入记录时,对添加了非空约束的列一定要给值;在修改记录时,不能把非空列的值设置为NULL。

    指定非空约束:

    CREATE TABLE stu(
             sid INT PRIMARY KEY AUTO_INCREMENT,
             sname VARCHAR(10) NOT NULL,
             age      INT,
             gender  VARCHAR(10)
    );

    当为sname字段指定为非空后,在向stu表中插入记录时,必须给sname字段指定值,否则会报错:

    INSERT INTO stu(sid) VALUES(1);

      插入的记录中sname没有指定值,所以会报错!

    4 唯一

    还可以为字段指定唯一约束!当为字段指定唯一约束后,那么字段的值必须是唯一的。这一点与主键相似!例如给stu表的sname字段指定唯一约束:

    CREATE TABLE tab_ab(
         sid INT PRIMARY KEY AUTO_INCREMENT,
         sname VARCHAR(10) UNIQUE
    );
     
      INSERT INTO sname(sid, sname) VALUES(1001, 'zs');
    INSERT INTO sname(sid, sname) VALUES(1002, 'zs');

      当两次插入相同的名字时,MySQL会报错!

    5 外键

    主外键是构成表与表关联的唯一途径!

    外键是另一张表的主键!例如员工表与部门表之间就存在关联关系,其中员工表中的部门编号字段就是外键,是相对部门表的外键。

    例如在t_section表中sid为1的记录说明有一个分类叫java,版主是t_user表中uid为1的用户,即zs!

    例如在t_topic表中tid为2的记录是名字为“Java是咖啡”的帖子,它是java版块的帖子,它的作者是ww。

    外键就是用来约束这一列的值必须是另一张表的主键值!!!

    创建t_user表,指定uid为主键列:

    CREATE TABLE t_user(
         uid  INT PRIMARY KEY AUTO_INCREMENT,
         uname  VARCHAR(20) UNIQUE NOT NULL
    ); 

    创建t_section表,指定sid为主键列,u_id为相对t_user表的uid列的外键:

    CREATE TABLE t_section(
             sid  INT PRIMARY KEY AUTO_INCREMENT,
             sname   VARCHAR(30),
             u_id INT,
             CONSTRAINT fk_t_user FOREIGN KEY(u_id) REFERENCES t_user(uid)
    );

    修改t_section表,指定u_id为相对t_user表的uid列的外键:

    ALTER TABLE t_section
    ADD CONSTRAINT fk_t_user
    FOREIGN KEY(u_id)
    REFERENCES t_user(uid);

    修改t_section表,删除u_id的外键约束:

    ALTER TABLE t_section
    DROP FOREIGN KEY fk_t_user;

    6 表与表之间的关系

    以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

    您可能感兴趣的文章:
    • 必须会的SQL语句(八) 数据库的完整性约束
    • 使用sql语句创建和删除约束示例代码
    • 使用tp框架和SQL语句查询数据表中的某字段包含某值
    • laravel实现查询最后执行的一条sql语句的方法
    • Laravel使用原生sql语句并调用的方法
    • 使用用SQL语句从电脑导入图片到数据库的方法
    • MyBatisPlus 自定义sql语句的实现
    上一篇:Mybatis中的动态SQL语句解析
    下一篇:mysql 8.0.18 安装配置方法图文教程(linux)
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    数据库中的sql完整性约束语句解析 数据库,中的,sql,完整性,