列的数据类型讲解

数值

  • 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目录下 一个文件夹对应一个数据,
    本质还是文件的存储!
    data
    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
  • 建议创表设置字符集编码
posted on 2022-10-10 10:18  depressiom  阅读(141)  评论(0编辑  收藏  举报