列的数据类型讲解
数值
-
tinyint 十分小的数据 1个字节
-
smallint 较小的数据 2个字节
-
mediumint 中等大小的数据 3个字节
-
int 标准的整数 4个字节 常用的 int
-
bigint 较大的数据 8个字节
-
float 浮点数 4个字节
-
double 浮点数 8个字节
-
decimal 字符串形式的浮点数 金融计算的时候,一般使用decimal (精度问题!)
字符串
-
char 字符串固定大小的 0~255
-
varchar 可变字符串 0~65535 常用的变量
-
tinytext 微型为本 2^8 - 1
-
text 文本串 2^16 - 1 保存大文本
时间日期
-
date YYYY-MM-DD,日期格式
-
time HH:mm:ss 时间格式
-
datetime YYYY-MM-DD HH:mm:ss 最常用的时间格式
-
timestamp 时间戳,1970.1.1到现在的毫秒数 比较常用
-
year 年份表示
null
-
没有值,未知
-
不要使用null进行运算,如果使用,结果为null
数据库的字段属性
Unsigned
-
无符号的整数
-
不能声明该列为负数
zerofill
-
0 填充的
-
不足的位数,使用0来填充
自增 auto_increment
-
自动在上一条记录的基础上+1(默认)
-
通常用来设计唯一的主键 index,必须是整数类型
-
可以自定义设计主键字自增的起始值和步长
非空 NULL not null
-
假设设置为not null ,不赋值会报错
-
NULL,如果不填写,默认为null
默认
-
设置默认的值
-
如果不指定该列的值,会填充默认值
手册规则
/**
* 每一个表,都必须存在一下五个字段! 做项目表示一个记录存在的意义
* id 主键
* version 乐观锁
* is_delete 伪删除
* gmt_create 创建时间
* gmt_update 更新时间
*/
创建数据库表
-- 注意 使用英文(),表的名称 和 字段
-- AUTO_INCREAMENT 自增
-- COMMENT 注释
CREATE TABLE IF NOT EXISTS 'student'(
`id` INT(4) NOT NULL AUTO_INCREMENT COMMENT '学号',
`name` VARCHAR(30) NOT NULL DEFAULT '匿名' COMMENT '姓名',
`pwd` VARCHAR(20) NOT NULL DEFAULT '123456' COMMENT '密码',
`sex` VARCHAR(5) NOT NULL DEFAULT '女' COMMENT '性别',
`birthday` DATETIME DEFAULT NULL COMMENT '出生日期',
`address` VARCHAR(100) DEFAULT NULL COMMENT '家庭地址',
`email` VARCHAR(50) DEFAULT NULL COMMENT '邮箱',
PRIMARY KEY (`id`)
)ENGINE=INNODB AUTO_INCREMENT=7 DEFAULT CHARSET = utf8 COMMENT='学生表';
常用命令
SHOW CREATE DATABASE school -- 查看创建数据库的语句
SHOW CREATE TABLE student -- 查看Student数据表的定义语句
DESC student -- 显示表的结构
数据表的类型 ENGINE=INNODB
- 关于数据库引擎
- INNODB 默认使用的
- MYISAM 早些年使用的
MYISAM | INNODB | --- |
---|---|---|
不支持 | 支持 | 事务支持 |
不支持 | 支持 | 数据行锁定 |
不支持 | 支持 | 外键约束 |
支持 | 不支持 | 全文索引 |
较小 | 较大,约为2倍 | 表空间的大小 |
常规操作
- MYISAM 节约空间,速度较快,
- INNODB 安全性高,事务的处理,多表多用户操作
在物理空间存在的位置
-
所有的数据库文件都存在 data目录下 一个文件夹对应一个数据,
本质还是文件的存储!
-
InnoDB 在数据库表中只有一个*.frm文件,以及上级目录下的 ibdata1 文件
-
Myisam 对应的文件
- *.frm 表结构的定义文件
- *.MYD 数据文件(data)
- *.MYI 索引文件(index)
设置数据表的字符编码
DEFAULT CHARSET = utf8
不设置的话,会是mysql默认的字符集编码
mysql中的默认编码是latin1(ISO_8859_1) 不支持中文
- 在 my.ini 中配置默认的编码
character-set-server = utf8
- 建议创表设置字符集编码
本文来自博客园,作者:depressiom,转载请注明原文链接:https://www.cnblogs.com/depressiom/p/16774725.html