MySQL字段属性

本文深入解析数据库中的字段属性,包括空值、默认值、自动增长、主键、唯一键及外键的概念与用法。详细介绍了如何在创建表时设置这些属性,以及它们在保证数据完整性和加快查询速度方面的作用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

字段属性
  1. 空值
  • null, not null
  1. 默认值
  • default
  • 需要在创建表时指定default才能使用
  1. 自动增长
  • auto_increment
  • 从1开始,每次加1,适合为记录生成唯一的id
  • 使用auto_increment必须是主键
  • 使用null默认增长
  • 自动增长的数据被删除,默认该编号不再被使用
  1. 主键
  • primary key
  • 一张表只能有一个主键
  • 创建组合主键: primary key(字段1, 字段2)
  • 特性:非空、唯一
  • 修改表添加主键:
  • 方法1: alter table 表名 add primary key 字段名;
  • 方法2:alter table表名 change 旧字段名 新字段名 新类型 primary key
  • 作用:保证数据完整性
  • 作用:加快查询速度
  • 主键创建原则:
    -1. 选择一个字段做主键
    -2. 选择数值类型
    -3. 选择改动较少的列做主键
  1. 唯一键
  • unique
  • 可以为空,一张表可以有多个唯一键
  • 删除唯一键比较特别:alter table t1 drop index id;
  • 键名默认是字段名
  • 为键名取名字:create table t1(id int, name varchar(20), unique UQ_name(name));
  • 查看唯一键: show create table t1\G
  • 删除唯一键:alter table t1 drop index UQ_name;
  1. 外键
  • 创建表添加外键:create table 9t2(t2id int, foreign key(t2id) references t1(t1id));
  • 修改表添加外键的用法: alter table t2 add foreign key(t2id) references t1(t1id)
  • 删除外键约束:alter table 从表名 drop foreign key 外键名
  • 主表中有的数据,从表才能添加
  • 从表有的数据,主表必须包含
  • 插入数据时,先添加主表,再添加从表
  • 删除应先删从表,再删主表
  • 置空操作和级联操作:create table 9t2(t2id int, foreign key(t2id) references t1(t1id) on delete set null on update cascade);
  1. comment

  2. SQL注释

  • 单行注释:–空格或#
  • 多行注释:/* */
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值