SQL中将数据类型分成三类
数值类型字符串类型时间日期类型
1>数值类型
整数型:存放整型数据
tinyint:迷你整型,使用1个字节存储,表示的状态最多为256种
smallint:小整型,使用2个字节存储,表示的状态最多为65536种
mediumint:中整型,使用3个字节存储
int:标准整型,使用4个字节存储
bigint:大整型,使用8个字节存储
小数型:带有小数点或者范围超出整型的数值类型
浮点型:小数点浮动,精度有限,而且会丢失精度
定点型:小数点固定,精度固定,不会丢失精度
2>时间日期类型
datetime:时间日期,格式是YYYY-mm-dd HH:ii:ss,表示的范围是从1000到9999年,有0值(0000-00-00 00:00:00)
timestamp:时间戳,但并不是时间戳,只是从1970年开始的,YYYY-mm-dd HH:ii:ss格式与datetime完全一致
year:年份,有两种形式:year(2)和year(4)
创建时间日期表
create table my_date(
d1 datetime,
d2 date,
d3 time,
d4 timestamp,
d5 year
)charset utf8;
插入数据
insert into my_date values('2020-2-12 10:30:18','2020-2-12','10:30:18',
'2020-2-12 10:30:18',2020);
时间使用负数
insert into my_date values
('2020-2-12 10:30:18','2020-2-12','-10:30:18',
'2020-2-12 10:30:18',2020);
insert into my_date values
('2020-2-12 10:30:18','2020-2-12','-210:30:18',
'2020-2-12 10:30:18',2020);
insert into my_date values
('2020-2-12 10:30:18','2020-2-12','-2 10:30:18',
'2020-2-12 10:30:18',2020);-- -2表示过去两天,就是四十八个小时
year可以使用两位或者四位
insert into my_date values
('2020-2-12 10:30:18','2020-2-12','10:30:18',
'2020-2-12 10:30:18',69);
('2020-2-12 10:30:18','2020-2-12','10:30:18',
'2020-2-12 10:30:18',70);
timestamp:修改记录
update my_date set d1='2020-02-12 20:20:20' where d5=2069;
使用函数获取时间戳
select unix_timestamp();
3>字符串类型
字符串类型分为:char、varchar、text、blob、enum、set(用的最多前三个)
char(定长字符串):磁盘(二维表)在定义结构的时候,就已经确定了最终数据的存储长度 ,效率高,磁盘空间大
适用于:身份证,电话号码,手机号,邮编
char(L):L代表Length,可以存储的长度,单位为字符,最大长度值可以为255
varchar(变长字符串):在分配空间的时候,按照最大的空间分配,但是实际上最终用了多少,是根据具体的数据来确定
适用于:收货地址,人名,邮箱等
varchar(L):L表示字符长度,理论长度是65536个字符,但是会多出1到2个字节,来确定存储的实际长度
定长(char)与变长(varchar)的区别:
定长(char):数据固定长度,磁盘空间比较浪费但效率高(身份证、电话号码、手机、邮箱)
变长(varchar):磁盘空间比较节约但效率低(名字、地址)
1>文本字符串:
如果数据量非常大,通常超过255个字符就会使用文本字符串
文本字符串根据存储的数据的格式分为:
text:存储文字、存储二进制数据的文件路径
blob:存储二进制数据(通常不用)
2>枚举字符串(enum)
枚举的使用方式:
enum(可能出现的元素列表);
例如:enum('男','女','不男不女','妖怪','保密');
使用:存储数据,只能存储上面定义好的数据
3>集合字符串:
跟枚举类似,实际存储的是数值,而不是字符串,但集合是多选
集合使用方式:
set(元素列表)
可以使用元素列表中的多个元素,使用逗号分隔
<1>列属性:
真正约束字段的是数据类型,但是这种约束很单一,需要有一些额外的约束,来更加保证数据的合法性,这就需要列属性
列属性包括:
NULL/NOT NULL(是/否可以为空)
default(默认值)
Primary key (主键)
unique key(唯一键)
auto_increment(自增长)
comment(描述)
<2>空属性:
两个值:NULL(默认的)、NOT NULL(不为空)
创建班级表
create table my_class(
name varchar(20) not null,
room varchar(20) null -- 代表允许为空,不写,默认就是允许为空
)charset utf8;
<3>列描述:
comment,描述,没有实际含义,是专门用来描述字段,会根据表创建语句保存,用来给程序员(数据库管理员)来进行了解的
创建表
create table my_teacher(
name varchar(20) not null comment '姓名',
money decimal(10,2) not null comment '工资'
)charset utf8;
<4>默认值:
default,某一种数据会经常性地出现某个具体的值,可以在一开始就指定好,在需要真实数据的时候,用户可以选择性地使用默认值
默认值
create table my_default(
name varchar(20) not null, -- 默认值null
age tinyint unsigned default 0, -- 默认值0
gender enum('男','女','保密') default '男' -- 默认值男
)charset utf8;
插入数据
insert into my_default (name) values('阿飞');
insert into my_default values('男闺蜜',18,default);