目录
照着下面样例创建表,设置自己的表名,字段和字段属性,基本都能满足需求啦:
参数解释:
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数据库创建表样例和解释...