数据库mysql中也是分不少数据类型的,最经常使用的就是:数字类型、字符类型、日期类型、枚举与集合类型mysql
1、数字类型:sql
默认都是有符号的,即正负号,若想无符号,在建立表时加unsigned。指定宽度时,只影响显示宽度不影响存储,即只决定读不决定写。数据库
注:其实咱们彻底不必为整数类型指定显示宽度,使用默认的就能够了session
最经常使用的是int,经常使用的通常是tinyint和int函数
tinyint:1个字节,有符号时可存(-128~127),无符号时可存(0~255),超过范围的数存成最大范围的那个数spa
smallint:2个字节,有符号时可存(-2^15~2^15 -1),无符号时可存(0~2^16 -1)code
mediumint:3个字节,有符号时可存(-2^23~2^23 -1),无符号时可存(0~2^24 -1)blog
int:4个字节,有符号是可存(-2^31~2^31 -1),无符号是可存(0~2^32 -1)内存
bigint:8个字节,有符号时可存(-2^63~2^63 -1),无符号时可存(0~2^64 -1)utf-8
另外还有浮点型:float、double和decimal
float和double不精准,超过精准范围的小数会被削为0,但在平常状况下已足够使用。decimal是精准浮点数,但比较消耗内存,因此在通常状况下建议使用float。格式为float(x,y),其中的x表明数字总个数不算符号,y表明保留的小数点位数
bit类型:用来存放二进制数,范围为1~64,不指定则默认1位
create table t1(id bit);#bit后可加括号指定范围,不指定默认为1
insert into t1 values(8);#在表中添加一个8
select bin(id),hex(id),oct(id) from t1;#查看时须要转换一下进制,须要什么进制呈现就用相应的函数
2、字符类型:宽度约束的是字符的个数
char:定长,不够宽度时用空格补齐。字符长度范围:0~255
特色:存取效率快,但浪费空间。存储时会在右侧填充空格以知足指定长度,但在查询时有自动删除空格。
varchar:变长,在指定宽度内存什么就是什么。字符长度范围:0~65535
特色:精准,节省空间但存储效率较慢。
注:虽然varchar更精准,但通常都是用char多一点,毕竟在精准度要求并无特别高的状况下效率比较重要
#查看字符的长度 select x,char_length(x) from t1; #查看字节的长度(utf-8中一个中文字符占三个字节) select x,length(x) from t1; #以上方式查看时,char会自动删除空格,需在查询前指定 set sql_mode='pad_char_to_full_length'; #才能够将char类型的数据完整的查看 #举例: create table t1(name1 char(10),name2 varchar(5)); insert into t1 values('ladygaga','egon'); select name1,char_length(name1),nam2,char_length(name2) from t1; select name1,length(name1),nam2,length(name2) from t1; #查询结果为8,4 #指定set sql_mode='pad_char_to_full_length';后查询结果为10,4
3、时间类型:根据不一样的需求选择不一样的时间类型
datetime:yyyy-mm-dd hh:mm:ss 范围为1000-01-01 00:00:00~9999-12-31 23:59:59
year:yyyy 范围为1901~2155,不管指定何种宽度,最后都是4
date:yyyy-mm-dd 范围为1000-01-01~9999-12-31
time:hh:mm:ss
单独插入时间时须要以字符的形式,按照对应格式。插入年份时尽可能使用4位值,若是用两位的话须要知道:当输入的2位<=69时,显示为20xx;当输入的的2位>=70时,显示为19xx。
举例:
create table t2(id int,born_date date,born_year year,reg_time datetime,class_time time); insert into t2 values(1,'alex',now(),now(),now(),now());#now()函数自动插入当前时间 insert into t2 values(2,'egon','2017-09-11','2017','2017-09-11 17:17:17','17:17:17');#标准形式 insert into t2 values(3,'eva','20170911','2017','20170911171717','171717');#这种形式也支持
4、枚举与集合: 字段只能在给定的范围内选择。枚举enum为单选,集合set为多选,可设定默认值
举例说明
create table t3 (id int primary key auto_increment,#自增id name=char(5), sex enum('male','female'),#枚举,二选一 hobbies set('eat','sleep','run','sing')#集合,多选 ); insert into t3 (name,sex,hobbies) values('egon','male','eat,sleep');
not null 和null:不为空和可为空,建立时指定,不指定时默认为可空
default:设置默认值的关键字,用来设置不传值时的默认值。若字段设置了默认值,插入空时填入的就是默认值
unique:标识该字段是惟一的
#方法一: create table t4(name char(10) unique); #方法二: create table t5(name char(10),constraint uk_name unique(name)); #联合惟一:表示多个字段联合惟一,只要有一个字段不一样便可插入,只有在全部字段都相同是才不可插入 create t6(id int,name char(10),host char(20) not null,port int not null,unique(host,port)); #将host和port联合惟一,若host和port都同样则不许插入 insert into t6(1,'mao',192.168.0.0',8080); insert into t6(2,'gou',192.168.0.1',8080); insert into t6(3,'zhu',192.168.0.1',8081);#均可插入 insert into t6(4,'ji',192.168.0.1',8081);#不可插入
primary key:主键,不为空且惟一
#方法一: create table t7(id int not null unique);#遵循不为空且惟一,但不是主键的正确表达式 #方法二: create table t7(id int primary key); #方法三: create table t7(id int,constraint pk_name primary key(id));
auto_increment:自增,被约束字段必须同时被key约束。对于自增的字段,delete删除后再插入值,该字段扔按照删除前的位置继续增加
auto_increment_offset:偏移量,默认值为1
auto_increment_increment:步长,默认值为1
全局范围内设置步长set global auto_increment_increment=2;
当前会话范围内设置步长set session auto_increment_increment=2;
同时设置偏移量和步长的状况下,若偏移量的值>步长的值,则偏移量的值就会被忽略,即失效,即偏移量=1
foreign key:外键,用于表的关联(重点!查询语句中最难点)
当有多张表,表1的多条记录能够对应到表2的一条记录时,就能够将其关联起来。此时必须保证表2的该记录是惟一的。
能够一对一关联,也能够多对一关联,多对多关联
举例:将下面的表进行相应的关联
要求:学生表关联班级表,课程表关联老师表,成绩表关联全部表
注:先创建父表,即要被关联的表,再创建子表并创建外键关联父表,同步更新on update cascade,同步删除on delete cascade。插入记录时先操做父表,再操做字表。