MySQL进阶12-- 数据类型介绍: 数值型/字符型/日期型-- 正负溢出保护/枚举型/set型/时间戳
/*进阶12
SQL 数据类型介绍
数值型:
整数: Tinyint(1b) < mediumint(3b)<smallint(2b) <int(4b) <bigint(8b)
( 默认有符号;
1/无符号类型:int unsigned; 正数轴长度加一倍;
2/如果插入的数据超出了规定的返回,则返回临界值
3/如果不设置长度,会有默认的长度;长度代表了显示的最大宽度,如果不够会用0在左边,但必须搭配zerofill填充!
--------------------) 小数: 1)....(M,D): M表示整数部位长度,D表示小数1部位长度;
2)M溢出后表示为9999.999; 定点数: dec(M,D),decimal(M,D),
1.默认为decimal(10,0)
2.精度更高,比如货币运算等运算则考虑使用
浮点数:
1.float(M,D) ,浮点数类型,4 个字节;
2.double(M,D) ,8个字节
枚举型: enum(...........);不区分大小写;
set 类型 : 不区分大小写,set类型最多里面可以保存0~64 个成员; ------------------- 字符型:
较短的文本:char(M:0--255) : (M可以省略,默认为1)可插入字符数上限 ,效率高,空间开支大
varchar(M:0--65535) : (M不可以省略)可变的字符数长度 ,效率低,空间相对低
较长的文本:text / blob(较长的二进制数据)
其他:
binary 和 varbinary用于保存较短的二进制;
enum 用于保存枚举
set用于保存集合
日期型:
date : 4b,仅保存年月日: 1000-01-01 , 9999-12-31
time : 仅保存时分秒
datetime : 8b ,不受时区影响, 最小值:1000-01-01 00:00:00 ,最大值:9999-12-31 23:59:59
timestamp(时间戳): 4b, 随时区改变而改变, 1970年-->2038年 */
#1 溢出保护
DROP TABLE IF EXISTS tab_int;
CREATE TABLE tab_int(
t1 INT,
t2 INT UNSIGNED );
INSERT INTO tab_int VALUES(100000000000000,-100); #2147483647,0
DESC tab_int;
SELECT * FROM tab_int;
#2 设置位数,0填充宽度
CREATE TABLE tab2_int(
t1 INT(7) ZEROFILL,
t2 INT(7) UNSIGNED ZEROFILL );
INSERT INTO tab2_int VALUES(123,123); # 0000123 , 0000123
DESC tab2_int;
SELECT * FROM tab2_int;
#3 测试溢出
CREATE TABLE tab_float(
f1 FLOAT(5,2),
f2 DOUBLE(5,2),
f3 DECIMAL(5,2)
); SELECT * FROM tab_float;
INSERT INTO tab_float VALUE(123.456,123.4444,123.55); #123.46,123.44,123.55
INSERT INTO tab_float VALUE(123.456,123.4444,123456.55); #123.46,123.44,999.99 #4 测试enum 枚举型
CREATE TABLE tab_char(
row1 ENUM('a','b','c','d')
);
INSERT INTO tab_char VALUES('a'); #a
INSERT INTO tab_char VALUES('M'); #' '
INSERT INTO tab_char VALUES('A'); #'a'
SELECT * FROM tab_char; #5 测试set 集合类型
DROP TABLE IF EXISTS tab_set;
CREATE TABLE tab_set(
row1 SET('a','b','c','d')
);
INSERT INTO tab_set VALUES('a,c,d'); #a SELECT * FROM tab_set; #四:日期型 CREATE TABLE tab_date(
t1 DATETIME,
t2 TIMESTAMP
);
INSERT INTO tab_date VALUES(NOW(),NOW()); #2018-10-29 15:13:24,2018-10-29 15:13:24
SELECT * FROM tab_date; SHOW VARIABLES LIKE 'time_zone'; SET time_zone='+9:00'; # 2018-10-29 15:13:24 ,2018-10-29 16:13:24
MySQL进阶12-- 数据类型介绍: 数值型/字符型/日期型-- 正负溢出保护/枚举型/set型/时间戳的更多相关文章
- MySQL 中的数据类型介绍(转)
据我统计,MySQL支持39种(按可使用的类型字段统计,即同义词也作多个)数据类型.下面的介绍可能在非常古老的mysql版本中不适用. 转载出处:http://blog.csdn.net/anxpp/ ...
- MySQL 中的数据类型介绍
1.MySQL 数据类型 MySQL中定义数据字段的类型对你数据库的优化是非常重要的. MySQL支持多种类型,大致可以分为三类:数值.日期/时间和字符串(字符)类型. 2.数值类型(12) 2.1. ...
- MySQL中的数据类型 [数值型、字符串型、时间日期型]
MySQL中的数据类型 [数值型.字符串型.时间日期型] MySQL中各数据类型 1. 数值类型(整型) 类型 数据大小 类型 (无符号:unsigned) 数据大小 存储空间 tinyint -12 ...
- 一、初识MySQL数据库 二、搭建MySQL数据库(重点) 三、使用MySQL数据库 四、认识MySQL数据库的数据类型 五、操作MySQL数据库的数据(重点)
一.初识MySQL数据库 ###<1>数据库概述 1. 数据库 长期存储在计算机内的,由组织的可共享的数据集合 存储数据的仓库 文件 ...
- MySQL:数据类型介绍
数据类型介绍 一.整数类型(可以添加自增约束条件) 数据类型 存储需要 有符号 无符号 tinyint 1个字节 -2^7~2^7-1 0~2^8 smallint 2个字节 -2^15~2^15-1 ...
- MySQL全面瓦解3:数据类型介绍与分析
概述 MySQL支持很多数据类型,以便我们能在复杂的业务场景中支持各种各样的数据格式,存储适当的数据内容.我们在设计数据库时,正确的使用数据库类型对整个数据库的整洁和高效,会有很大的帮助. 目前常用的 ...
- mysql进阶(十)不靠谱的FLOAT数据类型
今天在设计数据表时,突然发现原来FLOAT原来是很不靠谱的,所以在这里建议大家换成DOUBLE类型, 原因是: 在mysql手册中讲到,在MySQL中的所有计算都是使用双精度完成的,使用float(单 ...
- Mysql(三)-2:数据类型
一 介绍 存储引擎决定了表的类型,而表内存放的数据也要有不同的类型,每种数据类型都有自己的宽度,但宽度是可选的 详细参考: http://www.runoob.com/mysql/mysql-data ...
- 存储引擎和表的操作(mysql中的数据类型、完整性约束)
一.存储引擎 .概念 MySQL中的数据用各种不同的技术存储在文件(或者内存)中.这些技术中的每一种技术都使用不同的存储机制.索引技巧.锁定水平并且最终提供广泛的不同的功能和能力. 通过选择不同的技术 ...
随机推荐
- js禁止退出当前页面
禁止用户退出网页,就一个添加窗体历史状态方法,代码很简单,但是建议大家不要去使用,会给用户带来不友好的体验,我这里只是学习这种方法,看到自己代码上有也知道在哪里改变这些代码,所以分享一下: 实现原理: ...
- luffy项目搭建流程(Django前后端分离项目范本)
第一阶段: 1.版本控制器:Git 2.pip安装源换国内源 3.虚拟环境搭建 4.后台:Django项目创建 5.数据库配置 6.luffy前 ...
- [转帖]单集群10万节点 走进腾讯云分布式调度系统VStation
单集群10万节点 走进腾讯云分布式调度系统VStation https://www.sohu.com/a/227223696_355140 2018-04-04 08:18 云计算并非无中生有的概念, ...
- EFCore中的导航属性
使用了这么久的EntityFrameworkCore框架,今天想来就其中的一个部分来做一个知识的梳理,从而使自己对于整个知识有一个更加深入的理解,如果你对EFCore中的实体关系不熟悉你需要有一个知识 ...
- 抓包curl解析
目录 背景 code 背景 抓包工具charles抓取的请求curl,是这样: curl -H ':method: POST' -H ':path: /client.action?functionId ...
- TypeScript 命名空间
随着代码的不断增加,我们需要有组织的组合代码.TypeScript在1.x版本中提供了命名空间的方式进行代码组织,这也是TypeScript官方代码的组织方式.同时,TypeScript还实现了Jav ...
- C++ 中的 多态性
一 .多态性 1.多态性概述:多态是指同样的消息被不同类型的对象接受时导致不同的行为 2.多态实现:编译时的多态:在编译的过程中确定了同名操作的具体对象. 运行时的多态:在程序运行过程中动态地确定 ...
- 考试应对(Java语法速览)
1.从命令行输入数据 格式:Scanner reader=new Scanner(System.in); 此reader对象可以使用的方法:nextBoolean(),nextByte(),nextS ...
- SQL——INSERT INTO(增)
一.INSERT INTO语句的基本用法 INSERT INTO 语句用于往表中插入新记录. student表: INSERT INTO语句有2种语法格式: 1.不指定列名,直接插入记录. 语法格式如 ...
- 基于UDP的编程
前提:基于Linux系统的学习 服务器端编程模型1 socket(2) 创建通讯端点,返回一个文件描述符fd2 bind(2) 将fd绑定到本地的地址和端口while(1){ 阻塞等待客户端请求数据的 ...