1000字范文,内容丰富有趣,学习的好帮手!
1000字范文 > mysql数据库创建表时通过设置什么属性可以设置字段编号自动增加_Mysql数据库创建表样

mysql数据库创建表时通过设置什么属性可以设置字段编号自动增加_Mysql数据库创建表样

时间:2020-08-20 19:02:26

相关推荐

mysql数据库创建表时通过设置什么属性可以设置字段编号自动增加_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后,数据库表会自动创建基于这个字段的索引。

mysql数据库创建表时通过设置什么属性可以设置字段编号自动增加_Mysql数据库创建表样例和解释...

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。