MySql 表结构修改、约束条件、表关系

表结构修改(alter)

  • 查看表的结构:desc 表名;
  • 修改表名:alter table 表名 rename to 新表名;
  • 修改字段名:alter table 表名 change 旧字段名 新字段名 数据类型;
  • 修改字段类型:alter table 表名 modify 字段名 数据类型;
  • 添加字段:alter table 表名 add [column] 新字段 数据类型;
  • 删除字段:alter table 表名 drop [column] 字段名;

约束条件

约束是一种限制,通过对表中的数据做出限制,来确保表中数据的完整性,唯一性

  • 默认约束(default)
    • 插入数据的时候,如果没有明确为字段赋值,则自动赋予默认值
    • 在没有设置默认值的情况下,默认值为NULL
  • 非空约束(not null)
    • 限制一个字段的值不能为空,insert的时候必须为该字段赋值
    • 空字符不等于NULL
  • 唯一约束(unique key)
    • 限制一个字段的值不重复,该字段的数据不能出现重复的
    • 确保字段中值的唯一
  • 主键约束(primary key)
    • 通常每张表都需要一个主键来体现唯一性,每张表里面只能有一个主键
    • 主键 = 非空 + 唯一
  • 自增长约束(auto_increment)
    • 自动编号,和主键组合使用,一个表里面只能有一个自增长
    • auto_increment 要求用在主键上
    • id int primary key auto_increment,
    • 或者
    • id int auto_increment , primary key(id)
    • 如果不想默认从1开始,从1000开始
    • ...(id int primary key auto_increment)auto_increment=1000;
  • 外键约束(foreign key)
    • 保持数据的一致性,我有的你一定有,你没有的,我绝对没有
    • foreign key (id_b) references a(id_a)

表关系

  • 一对一
    • 用外键的方式,把两个表的主键关联
  • 一对多
    • 通过外键关联来实现这种关系
  • 多对多
    • 对于多对多关系,需要创建中间表实现
    • 例如学生选课
    • 选课表(中间表)的学生id和课程id分别是学生表和课程表的外键




你可能感兴趣的:(MySql 表结构修改、约束条件、表关系)