Mysql数据库创建表样例和解释

目录

照着下面样例创建表,设置自己的表名,字段和字段属性,基本都能满足需求啦:

参数解释:

1. AUTO_INCREMENT是设置该字段为自增列:

2. COMMENT '邮箱' :字段备注邮箱

3. UNSIGNED  数字类型无符号化

4.ZEROFILL   缺位补0显示

5. ENGINE=InnoDB 设置表的存储引擎类型为InnoDB,支持外键和事务处理

6. DEFAULT CHARSET=utf8 设置的是数据库表默认字符编码为utf8

7. PRIMARY KEY (id)  设置id字段主键约束

8.UNIQUE KEY (name)设置name字段唯一性约束


照着下面样例创建表,设置自己的表名,字段和字段属性,基本都能满足需求啦:

CREATE TABLE test1(
id       bigint(20) NOT NULL AUTO_INCREMENT,         # 自增列为id
name VARCHAR(255) DEFAULT NULL COMMENT '姓名',        #name字段默认为空,备注为姓名
age    INT(10) UNSIGNED NOT NULL DEFAULT '0',        #age是无符号字段,不可为空,默认0
student_number int(10) UNSIGNED ZEROFILL,            # student_number一共10位,缺位补0
PRIMARY KEY (id)                                     # 设置id是主键
UNIQUE KEY (name)                                  # name设置唯一性约束
)ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8 # 存储引擎为InnoDB,自增列值从1开始累加,默认编码为UTF8

参数解释:

1. AUTO_INCREMENT是设置该字段为自增列:

  • 必须设置在主键+整数类型数据列字段上
  • 序号的最大值受该列的数据类型约束,如TINYINT数据列的最大编号是127,如加上UNSIGNED,则最大为255。一旦达到上限,AUTO_INCREMENT就会失效。
  • AUTO_INCREMENT=1 指 从1开始增长,当你把第一条记录删除时,再插入第二跳 数据时,主键值是2,不是1
  • 重设自增的起始值n:alter table table_name AUTO_INCREMENT=【n】
  • 如果要人工插入自增列,如果列值与已有的值重复,则会出错。如果大于已有值,则下一个编号从该值开始递增。
  • 当进行全表删除时,会从1重新开始编号。
  • 获取最后新增值: last_insert_id()

2. COMMENT '邮箱' :字段备注邮箱

建表最好养成良好的习惯,给字段加中文备注,因为建表的时候字段都是英文,多了可能不知道代表什么,还有的为了隐私保护字段名用元素代码表示,此时写个comment,就便于查看这个列表示的是什么数据。

3. UNSIGNED  数字类型无符号化

是一种数据类型设置,要和数据类型int等一起用,适用于没有负数还想增加数据范围的情况(增加数据范围也可以将INT类型提升为BIGINT类型)

比如:INT的类型范围-2147483648~2147483647

INT UNSIGNED范围0~4294967295

4.ZEROFILL   缺位补0显示

只是输出显示属性的设置,不更改存储方式,当插入mysql中该字段的值的长度小于定义的长度时,会在数值前面补全相应数据的0。

比如 int(4) zerofill

输入 1的时候,显示0001,会自动补全0;但是数据库内部存储还是1,0001只是格式化输出显示而已

5. ENGINE=InnoDB 设置表的存储引擎类型为InnoDB,支持外键和事务处理

       ENGINE=MyISAM       MyISAM不支持事务处理等高级处理

6. DEFAULT CHARSET=utf8 设置的是数据库表默认字符编码为utf8

7. PRIMARY KEY (id)  设置id字段主键约束

主键不可重复,不为空,且每表只有一个

 

8.UNIQUE KEY (name)设置name字段唯一性约束

可用来防止数据插入的时候重复的,建立UNIQUE KEY后,数据库表会自动创建基于这个字段的索引。

 

你可能感兴趣的:(Sql运用)