博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
MySQL数据类型
阅读量:5923 次
发布时间:2019-06-19

本文共 9232 字,大约阅读时间需要 30 分钟。

一、MySQL数据类型     1.数值类型         1)整数类型         整数类型:TINYINT SMALLINT MEDIUMINT INT BIGINT         作用:存储年龄,等级,id,各种号码等         tinyint[(m)] [unsigned] [zerofill]             小整数,数据类型用于保存一些范围的整数数值范围:             有符号:                 -128 ~ 127             无符号:                 0 ~ 255             PS: MySQL中无布尔值,使用tinyint(1)构造。         int[(m)][unsigned][zerofill]             整数,数据类型用于保存一些范围的整数数值范围:             有符号:                     -2147483648 ~ 2147483647             无符号:                     0 ~ 4294967295         bigint[(m)][unsigned][zerofill]             大整数,数据类型用于保存一些范围的整数数值范围:             有符号:                     -9223372036854775808 ~ 9223372036854775807             无符号:                     0  ~  18446744073709551615         注意:为该类型指定宽度时,仅仅只是指定查询结果的显示宽度,与存储范围无关,存储范围如下         其实我们完全没必要为整数类型指定显示宽度,使用默认的就可以了         默认的显示宽度,都是在最大值的基础上加1

                  

2)浮点类型         定点数类型  DEC等同于DECIMAL           浮点类型:FLOAT DOUBLE         作用:存储薪资、身高、体重、体质参数等         #FLOAT[(M,D)] [UNSIGNED] [ZEROFILL]         定义:                 单精度浮点数(非准确小数值),m是数字总个数,d是小数点后个数。m最大值为255,d最大值为30         有符号:                    -3.402823466E+38 to -1.175494351E-38,                    1.175494351E-38 to 3.402823466E+38         无符号:                    1.175494351E-38 to 3.402823466E+38         精确度:                    **** 随着小数的增多,精度变得不准确 ****         #DOUBLE[(M,D)] [UNSIGNED] [ZEROFILL]         定义:                    双精度浮点数(非准确小数值),m是数字总个数,d是小数点后个数。m最大值为255,d最大值为30         有符号:                    -1.7976931348623157E+308 to -2.2250738585072014E-308                    2.2250738585072014E-308 to 1.7976931348623157E+308         无符号:                    2.2250738585072014E-308 to 1.7976931348623157E+308         精确度:                    ****随着小数的增多,精度比float要高,但也会变得不准确 ****         decimal[(m[,d])] [unsigned] [zerofill]         定义:                   准确的小数值,m是数字总个数(负号不算),d是小数点后个数。 m最大值为65,d最大值为30。         精确度:                    **** 随着小数的增多,精度始终准确 ****                    对于精确数值计算时需要用此类型                    decaimal能够存储精确值的原因在于其内部按照字符串存储。     2.字符串类型         char和 varchar 是最常使用的两种字符串类型。         char(N)用来保存固定长度的字符串,对于 char 类型,N 的范围 为 0 ~ 255         varchar(N)用来保存变长字符类型,对于 varchar 类型,N 的范围为 0 ~ 65 535         char(N)和 varchar(N) 中的 N 都代表字符长度,而非字节长度。         char类型:定长,简单粗暴,浪费空间,存取速度快         字符长度范围:0-255(一个中文是一个字符,是utf8编码的3个字节)         存储:             存储char类型的值时,会往右填充空格来满足长度             例如:指定长度为10,存>10个字符则报错,存<10个字符则用空格填充直到凑够10个字符存储         检索:             在检索或者说查询时,查出的结果会自动删除尾部的空格,除非我们打开pad_char_to_full_length SQL模式(SET sql_mode = 'PAD_CHAR_TO_FULL_LENGTH';)         varchar类型:变长,精准,节省空间,存取速度慢             字符长度范围:0-65535(如果大于21845会提示用其他类型 。mysql行最大限制为65535字节,字符编码为utf-8:https://dev.mysql.com/doc/refman/5.7/en/column-count-limit.html)             存储:                 varchar类型存储数据的真实内容,不会用空格填充,如果'ab  ',尾部的空格也会被存起来                 强调:varchar类型会在真实数据前加1-2Bytes的前缀,该前缀用来表示真实数据的bytes字节数(1-2Bytes最大表示65535个数字,正好符合mysql对row的最大字节限制,即已经足够使用)                 如果真实的数据<255bytes则需要1Bytes的前缀(1Bytes=8bit 2**8最大表示的数字为255)                 如果真实的数据>255bytes则需要2Bytes的前缀(2Bytes=16bit 2**16最大表示的数字为65535)             检索:                 尾部有空格会保存下来,在检索或者说查询时,也会正常显示包含空格在内的内容

          

3.日期类型         DATE TIME DATETIME TIMESTAMP YEAR         作用:存储用户注册时间,文章发布时间,员工入职时间,出生时间,过期时间等         year             YYYY(1901/2155)         date             YYYY-MM-DD(1000-01-01/9999-12-31)         time             HH:MM:SS('-838:59:59'/'838:59:59')         datetime             YYYY-MM-DD HH:MM:SS(1000-01-01 00:00:00/9999-12-31 23:59:59    Y)         timestamp             YYYYMMDD HHMMSS(1970-01-01 00:00:00/2037 年某时)         补充:         datetime和timestamp 区别:         1.DATETIME的日期范围是1001——9999年,TIMESTAMP的时间范围是1970——2038年。         2.DATETIME存储时间与时区无关,TIMESTAMP存储时间与时区有关,显示的值也依赖于时区。           在mysql服务器,操作系统以及客户端连接都有时区的设置。         3.DATETIME使用8字节的存储空间,TIMESTAMP的存储空间为4字节。因此,TIMESTAMP比DATETIME的空间利用率更高。         4.DATETIME的默认值为null;TIMESTAMP的字段默认不为空(not null),默认值为当前时间     4.枚举类型和集合类型         字段的值只能在给定范围中选择,如单选框,多选框         枚举 enum 单选 只能在给定的范围内选一个值,如性别 sex 男male/女female         集合 set 多选 在给定的范围内可以选择一个或一个以上的值(爱好1,爱好2,爱好3...)         枚举类型(enum)         示例:             CREATE TABLE shirts (                 name VARCHAR(40),                 size ENUM('x-small', 'small', 'medium', 'large', 'x-large')             );             INSERT INTO shirts (name, size) VALUES ('dress shirt','large'), ('t-shirt','medium'),('polo shirt','small');         集合类型(set)         示例:             CREATE TABLE myset (col SET('a', 'b', 'c', 'd'));             INSERT INTO myset (col) VALUES ('a,d'), ('d,a'), ('a,d,a'), ('a,d,d'), ('d,a,d');
二、完整性约束         约束条件与数据类型的宽度一样,都是可选参数         作用:用于保证数据的完整性和一致性         主要分为:         PRIMARY KEY (PK)    标识该字段为该表的主键,可以唯一的标识记录         FOREIGN KEY (FK)    标识该字段为该表的外键         NOT NULL    标识该字段不能为空         UNIQUE KEY (UK)    标识该字段的值是唯一的         AUTO_INCREMENT    标识该字段的值自动增长(整数类型,而且为主键)         DEFAULT    为该字段设置默认值         UNSIGNED 无符号         ZEROFILL 使用0填充     1.not null与default         是否可空,null表示空,非字符串         not null - 不可空         null - 可空         默认值,创建列时可以指定默认值,当插入数据时如果未主动设置,则自动添加默认值null         create table tb1(         nid int not null defalut 2,         num int not null)         mysql> create table t1(id int); #id字段默认可以插入空         mysql> desc t1;         +-------+---------+------+-----+---------+-------+         | Field | Type    | Null | Key | Default | Extra |         +-------+---------+------+-----+---------+-------+         | id    | int(11) | YES  |     | NULL    |       |         +-------+---------+------+-----+---------+-------+         mysql> insert into t1 values(); #可以插入空         mysql> create table t2(id int not null); #设置字段id不为空         mysql> desc t2;         +-------+---------+------+-----+---------+-------+         | Field | Type    | Null | Key | Default | Extra |         +-------+---------+------+-----+---------+-------+         | id    | int(11) | NO   |     | NULL    |       |         +-------+---------+------+-----+---------+-------+         mysql> insert into t2 values(); #不能插入空         ERROR 1364 (HY000): Field 'id' doesn't have a default value         #设置id字段有默认值后,则无论id字段是null还是not null,都可以插入空,插入空默认填入default指定的默认值         mysql> create table t3(id int default 1);         mysql> alter table t3 modify id int not null default 1;     2.unique         #单列唯一         create table t16(             id int unique,             name char(16)         );         联合唯一             create table server(                 id int unique,                 ip char(15),                 port int,                 unique(ip,port)             );     3.primary key         #primary key:单单从约束角度去看,primary key就等同于not null unique         #强调(******)         1、一张表中必须有,并且只能有一个主键         2、一张表中都应该有一个id字段,而且应该把id字段做成主键         create table t17(             id int primary key,             name char(16),             age int,             sex char(6)         )engine=innodb;         #联合主键         create table t19(             ip char(15),             port int,             primary key(ip,port)         );         # primary key auto_increment         create table t20(             id int primary key auto_increment,             name char(16)         )engine=innodb;         # auto_increment注意点:         1、通常与primary key连用,而且通常是给id字段加         2、auto_incremnt只能给被定义成key(unique key,primary key)的字段加     4. auto_increment         # primary key auto_increment         create table t20(             id int primary key auto_increment,             name char(16)         )engine=innodb;         auto_increment注意点:         1、通常与primary key连用,而且通常是给id字段加         2、auto_incremnt只能给被定义成key(unique key,primary key)的字段加         #也可以指定id         mysql> insert into student values(4,'asb','female');         Query OK, 1 row affected (0.00 sec)         mysql> insert into student values(7,'wsb','female');         #对于自增的字段,在用delete删除后,再插入值,该字段仍按照删除前的位置继续增长         mysql> delete from student;         Query OK, 4 rows affected (0.00 sec)         mysql> insert into student(name) values('ysb');         应该用truncate清空表,比起delete一条一条地删除记录,truncate是直接清空表,在删除大表时用它         mysql> truncate student;         Query OK, 0 rows affected (0.01 sec)         mysql> insert into student(name) values('egon');         了解:         #在创建完表后,修改自增字段的起始值         create table student(             -> id int primary key auto_increment,             -> name varchar(20),             -> sex enum('male','female') default 'male'             -> );         alter table student auto_increment=3;         mysql> insert into student(name) values('egon');         #也可以创建表时指定auto_increment的初始值,注意初始值的设置为表选项,应该放到括号外         create table student(         id int primary key auto_increment,         name varchar(20),         sex enum('male','female') default 'male'         )auto_increment=3;         设置步长         sqlserver:自增步长             基于表级别             create table t1(                 id int。。。             )engine=innodb,auto_increment=2 步长=2 default charset=utf8         mysql自增的步长:             show session variables like 'auto_inc%';             #基于会话级别             set session auth_increment_increment=2 #修改会话级别的步长             #基于全局级别的             set global auth_increment_increment=2 #修改全局级别的步长(所有会话都生效)

转载于:https://www.cnblogs.com/zhaodafa/p/9009242.html

你可能感兴趣的文章
jQuery的before()方法的超简易版,用于个人理解源码以及回调函数
查看>>
幸运大转盘抽奖 抽奖算法 程序实现逻辑
查看>>
IntelliJ IDEA系列编辑器安装GO插件
查看>>
程序员(程序媛)容易忽略的几个细节!
查看>>
git常用指令(持续更新)
查看>>
Foundation对象(字典,数组等)转换为json串
查看>>
QQ分享链接控制抓取内容
查看>>
ssh整合分解
查看>>
移动网站设计与开发的碎碎念
查看>>
图解基础认知之mybatis框架及请求过程
查看>>
Java 10 实战第 1 篇:局部变量类型推断
查看>>
go语言学习
查看>>
机器人如何懂得人类感情
查看>>
深入理解高并发下分布式事务的解决方案
查看>>
WP7有关定位服务应用审核的注意事项
查看>>
精通Spring Boot ——第十七篇:Spring Security自定义登录逻辑
查看>>
线性代数---单位矩阵和逆矩阵
查看>>
ActiveMQ 的安装
查看>>
Ajax版SSM整合前的准备工作
查看>>
【整理】Python之JIT、Django、Greenlet和Stackless
查看>>