1. 日期和时间
日期和时间类型在数据库中也非常重要,比如我们在数据库中新增了一个用户,我们就应该要存储用户加入的时间,方便以后的查询。
还有比如我们在记录日志的时候,谁操作了哪个地方,我们也需要有时间的参与,才能知道,谁在什么时候操作了什么。
1.1 日期时间
表示:datetime / date /year/time/timestamp
1.2 datetime / date / year /time
date 保存的是年月日。
datetime保存的是 年月日时分秒
year: 保存的是年份
time: 保存时分秒
可以看出 datetime更加占用空间,它占用8个字节。
1.3 timestamp时间错
占用4个字节。
范围在:1970-2038年。
1.4. 常用的保存时间的方式:
在真实的项目中,时间的保存我们通常使用一个整数类型来保存一个数字,用来表示时间戳,时间戳是从1970年1月1日0:0:0开始的以秒为单位的数字,
2. 创建数据表的示例:
创建一张用户表,需要有:用户名、昵称、手机号码、邮箱、年龄、注册时间等字段。
分析:
用户名、昵称、手机号码、邮箱都应该是字符串类型。不同的是,手机号码在中国都是11位,所以手机号码可以使用char类型。
年龄应该是一个数字类型,而且年龄应该都小于200.所以使用tinyint类型就可以满足。
注册时间用来表示一个时间,可以使用时间戳的方式。
create table if not exists `user` (
`id` int(11) unsigned auto_increment,
`username` varchar(15),
`nickname` varchar(10),
`phone` char(11),
`age` tinyint(3),
`create_time` int(11) unsigned,
primary key(`id`)
)engine=innodb default charset=utf8;
3. 练习
创建公司员工的考勤表,需要创建多张表。
1. 员工表
2. 员工打卡记录表
4. 附录(类型总结)
类型 | 范围 | 说明 | DEMO |
tinyint | -128 - 127unsigned:0-255 | 1个字节整数 | column_name tinyint(3) |
smallint | -32768 - 32767unsigned:0-65535 | 2个字节整数 | column_name smallint(5) |
mediumint | -8388608 - 8388607unsigned:0-16777215 | 3个字节整数 | colum_name mediumint(7) |
int | -2^31 ~ 2^31 -1unsigned:0~2^32 | 4个字节整数 | column_name int(10) |
bigint | -2^63 ~ 2^63 - 1unsigned:0 ~ 2^64 | 8个字节整数 | col_name bigint(16) |
float(M,D) | -3.4E+38 ~ 3.4E+38(约) | 4个字节小数 | |
double(M,D) | -1.79E+308 ~ 1.79E+308(约) | 8个字节小数 | |
decimal(M,D) | 精准的小数存储 | ||
char(N) | N = 1 ~ 255 | 定长 | |
varchar(N) | N = 1 ~ 65535 | 变长(需要单独拿出1-2个字节存储真实长度) | |
tinytext | 最大255个字符 | ||
text | 最大65535个字符 | ||
mediumtext | 最大16777215个字符 | ||
longtext | 最大4284967295和字符 | ||
date | 日期(yyyy-mm-dd) | ||
time | 时间(hh:mm:ss) | ||
datetime | 日期时间(yyyy-mm-dd hh:mm:ss) | ||
timestamp | yymmddhhmmss | ||
year | 年(yyyy) |