MySQL之数据类型(常用)
MySQL-data_type数据类型
1、查看数据类型
mysql> help data type //通过help对数据进行查看,以及使用的方法
2、MySQL常见的数据类型
整数int、定点小数dec、浮点数float、字符串varchar、时间、布尔bool、位
前言========================================
在MySQL数据库中,进行数据存储时,难免会出现数据类型转换,其中就包括:隐式类型转换、显示类型转换
1、隐式类型转换:有害、无害
①对于新建表列
数字:int、decimal
字符串:varchar
日期:date
②查select、增insert时,对于常量
数字:不要加引号(非一定)
字符串:一定要加上引号
日期:可以加上引号,也可以不加---最好是加上
2、显式类型转换:调用cast函数
格式:
cast(expr as type)
---将任意类型的表达式expr转换成指定类型type的值
mysql> select cast(19950101 as date);
+------------------------+
| cast(19950101 as date) |
+------------------------+
| 1995-01-01 |
+------------------------+
常见的类型转换:
字符串char--->数字、日期
数字--->字符串、日期
日期date--->数字、字符串
===========================================
常用的数据类型:
一、整数:
每个整型类型可以指定一个最小显示宽度(注意:这个宽度并不表示存储的值有多大)
基本格式:
INT[(M)] [UNSIGNED] [ZEROFILL]
①M:指定显示宽度(默认是M=10),以实际的取值范围为准,值超过显示宽度,显示宽度自动增加
②unsigned:无符号的,表示只允许正数,所以取值范围取绝对值且最大值*2
(例:int unsigned range is 0 to 4294967295)
③zerofill: 填充0(如果声明了zerofill,该列会自动设为unsigned)
影响数字的显示方式:
如果一个数字的宽度小于所允许的最大宽度,这个值前面会用0填充
如果宽度大于所允许的最大宽度但不超过取值范围,以实际的取值范围为准,不填0;超出取值范围的报错不存储。
示例:
mysql> create table t1(id int zerofill); #默认显示宽度10
mysql> insert into t1 values(-1); #取值范围:0--4294967295
ERROR 1264 (22003): Out of range value for column 'id' at row 1
mysql> insert into t1 values(123);
mysql> insert into t1 values(12300);
mysql> insert into t1 values(1.123);
mysql> select * from t1;
+------------+
| id |
+------------+
| 0000000123 |
| 0000012300 |
| 0123456789 |
| 0000000001 |
+------------+
解析:因为建表的设置是int整数,小数点后的数会四舍五入
二、(定点)小数: decimal(dec)精确小数类型---精确数的存储
同义词:decimal=dec=numeric=fixed
基本格式:
DEC[(M[,D])] [UNSIGNED] [ZEROFILL]
①M:精度,(整数位数+小数位数)不包含小数点的数字总位数(1--30),不指定默认为10
②D:小数位数,如果不指定,默认为0
若位数不够,小数末尾补零;若位数超预算(整数位数=M-D),报错。
示例:
mysql> create table t2(id dec(5,3) unsigned);
##数字总位数5
##整数位数5-3=2(不够没关系;超出报错)
##小数位数3(不够补零;超出四舍五入)
mysql> insert into t2 values(12.345);
mysql> insert into t2 values(1.23);
mysql> insert into t2 values(123);
ERROR 1264 (22003): Out of range value for column 'id' at row 1
mysql> insert into t2 values(12.3456);
mysql> select * from t2;
+--------+
| id |
+--------+
| 12.345 |
| 1.230 |
| 12.346 |
+--------+
dec的小数位数是个定数;
三、浮点数: float/double单精度、双精度浮点类型
基本格式:
float[(length) | (<display width>,<scale>)]
double[(precision) | (<display width>,<scale>)]
两者区别在于值所保留的存储空间数量不同
注意:
由于对一个浮点数字来说,可用的存储空间有限,如果一个数字非常大或非常小,将存储这个数字的近似值而不是实际值。
①使用一个参数来指定浮点类型
length(precision):在一个浮点数据类型中可以指定长度,来确定具体的浮点类型
0~24:单精度float,从第7位有效位,进行四舍五入存储
25~30:双精度double,从第16位有效位,进行四舍五入存储
mysql> create table t3(id float(8));
//m=8,说明是单精度,存储6位的近似值(第7位四舍五入,后面为0)
mysql> insert into t3 values(123);
mysql> insert into t3 values(1234567);
mysql> insert into t3 values(123456789);
mysql> insert into t3 values(123456789.123456789);
mysql> select * from t3;
+-----------+
| id |
+-----------+
| 123 |
| 1234570 |
| 123457000 |
| 123457000 |
+-----------+
②使用两个参数来指定浮点类型
单精度float(m,d):m表示精度(0~24),d表示小数位数
双精度double(m,d):m表示精度(25~30),d表示小数位数
具有宽度和小数位数的float的同义词:real和float4;指定double=float(30)
示例:设一个字段定义为float(5,3)---单精度浮点,精度5,小数位3(和dec一样)
mysql> create table t_3(id float(5,3) unsigned);
##数字总位数5
##整数位数5-3=2(不够没关系;超出报错)
##小数位数3(不够补零;超出四舍五入)
mysql> insert into t_3 values(123);
ERROR 1264 (22003): Out of range value for column 'id' at row 1
mysql> insert into t_3 values(12.3);
mysql> insert into t_3 values(12.3456);
mysql> insert into t_3 values(1.23456);
mysql> select * from t_3;
+--------+
| id |
+--------+
| 12.300 |
| 12.346 |
| 1.235 |
+--------+
float的小数位数不是固定的;
超出存储范围,近似值进行存储。
四、字符串: varchar可变长字符串类型
1.char(n):固定长度,最多255个字符
2.varchar(n):固定长度,最多65535个字符
3.tinytext:可变长度,最多255个字符
4.text:可变长度,最多65535个字符
5.mediumtext:可变长度,最多2的24次方-1个字符
6.longtext:可变长度,最多2的32次方-1个字符
示例:
mysql> create table t4(name varchar(21));
mysql> insert into t4 values(123);
mysql> insert into t4 values(xiaoming);
ERROR 1054 (42S22): Unknown column 'xiaoming' in 'field list' #字符串要用引号引起来
mysql> insert into t4 values('xiaoming');
mysql> insert into t4 values('zhang'san');
'> ^C
!!!字符串中的单引号用单引号进行转义
mysql> insert into t4 values('zhang''san');
mysql> select * from t4;
+-----------+
| name |
+-----------+
| 123 |
| xiaoming |
| zhang'san |
+-----------+
若要存储中文字符串,需要进行字符设置
create table tableName(列名 varchar(20) character set utf8);
create table tableName(列名 varchar(20) character set gpk);
1、char和varchar的区别:
①char(n) 若存入字符数小于n,则以空格补于其后,查询之时再将空格去掉。所以char类型存储的字符串末尾不能有空格,varchar不限于此。
②char(n) 固定长度,char(4)不管是存入几个字符,都将占用4个字节,varchar是存入的实际字符数+1个字节(n<=255)或2个字节(n>255),所以varchar(4),存入3个字符将占用4个字节。
③char类型的字符串检索速度要比varchar类型的快。
2、varchar和text的区别:
①varchar可指定n,text不能指定,内部存储varchar是存入的实际字符数+1个字节(n<=255)或2个字节(n>255),text是实际字符数+2个字节。
②text类型不能有默认值。
③varchar可直接创建索引,text创建索引要指定前多少个字符。varchar查询速度快于text,在都创建索引的情况下,text的索引似乎不起作用。
五、日期时间时区
date:日期 '2008-12-02'
time:时间 '12:25:36'
datetime:日期时间 '2008-12-12 22:06:44'
timestamp:自动存储记录修改时间(如果数据库里面有timestamp数据类型,就应该考虑时区问题)
示例:
mysql> create table t5(d1 date);
mysql> insert into t5 values(19901101); #推荐的正统写法
mysql> insert into t5 values(901101);
mysql> insert into t5 values(1990111); #有问题的写法
mysql> select * from t5;
+------------+
| d1 |
+------------+
| 1990-11-01 |
| 1990-11-01 |
| 0199-01-11 |
+------------+
1、获得当前日期时间的函数
①获得当前日期+时间(date+time)函数:now()、sysdate()
区别:now()在执行开始时值就得到了,sysdate()在函数执行时动态得到值
②获得当前日期curdate()、获得当前时间curtime()
mysql> select curdate(),curtime();
+------------+-----------+
| curdate() | curtime() |
+------------+-----------+
| 2017-03-21 | 11:00:25 |
+------------+-----------+
========================================
1)日期字符串转换函数format:
date_format(date,format)
---将日期date按照给定的模式format转换成字符串
time_format(time,format)
---将时间time按照给定的模式format转换成字符串,format中只可以使用时、分、秒、微秒模式元素
format中可使用的模式元素可查官方文档
2)日期字符串转换函数
str_to_date(str,format)
---将字符串str以指定的模式format转换成日期
mysql> select str_to_date('01,5,2013','%d,%m,%Y');
mysql> select str_to_date('May 1, 2013','%M %d,%Y');
如果在会话变量@@sql_mode设置中包含no_zero_date和no_zero_in_date时,上述转换将会失败,没有包含这些设置时则转换成功。
========================================
③获得当前 UTC 日期时间函数:utc_date(), utc_time(), utc_timestamp()
2、MySQL时区问题:重点!!!
注意:当数据库里面有timestamp数据类型的列,就应该考虑时区参数
问:如何判断是否有timestamp数据类型的列?
答:
mysql> select table_name,column_name,data_type
-> from information_schema.columns
-> where
-> data_type='timestamp';
……
MySQL是安装在Linux操作系统下面,因此MySQL时区跟Linux的时区有很多关联的地方,MySQL里有一个时区叫做系统时区,MySQL系统时区的存在是为MySQL安装后读取Linux操作系统的时区,将自己的系统时区设置为与Linux操作系统一致 的时区:
mysql> show variables like "system%"; #查看系统时区
+------------------+-------+
| Variable_name | Value |
+------------------+-------+
| system_time_zone | CST |
+------------------+-------+
Linux 操作系统的时区(有很多选择)与 mysql 中的系统时区是一致的
Linux操作系统的时区
shell> cat /etc/sysconfig/clock
区域信息目录:/usr/share/zoneinfo
但是,系统时区的选择对后续 mysql 的操作影响不大,但是 mysql 中还
mysql> show variables like "%time_zone%";
+------------------+--------+
| Variable_name | Value |
+------------------+--------+
| system_time_zone | CST |
| time_zone | SYSTEM |
+------------------+--------+
mysql> select @@global.time_zone; #查看全局时区
mysql> select @@session.time_zone; #查看会话时区(默认等于全局时区)
1.临时设置时区(全局):
①'+8:00'格式
mysql> set @@global.time_zone='+8:00';
②'Asia/Shanghai'格式
mysql> set @@global.time_zone='Asia/Shanghai';
ERROR 1298 (HY000): Unknown or incorrect time zone: 'Asia/Shanghai'
加载系统时区:
shell> mysql_tzinfo_to_sql /usr/share/zoneinfo |mysql -uroot -p123 mysql
mysql> set @@global.time_zone='Asia/Shanghai';
2.永久设置时区:
修改配置文件vim /etc/my.cnf
[mysqld]区域中添加default_time_zone=Asia/Shanghai
时区的正确实践(只有timestamp数据类型的才有意义):
①insert以前,你的values对应的时间到底是哪个时区,然后设置set @@session.time_zone为对应的时区
②select获取以前,你想得到什么时区的时间,就设置set @@session.time_zone为对应的时区。
示例:
会话1:当前会话
mysql> select @@global.time_zone;
+--------------------+
| @@global.time_zone |
+--------------------+
| +08:00 |
+--------------------+
mysql> create table t9(tm timestamp);
mysql> insert into t9 values('2017-3-22 10:10');
mysql> select * from t9;
+---------------------+
| tm |
+---------------------+
| 2017-03-22 10:10:00 |
+---------------------+
会话2:客户端登录会话(东10区用户)
设置会话时区
mysql> set @@session.time_zone='+10:00';
mysql> use test;select * from t9;
Database changed
+---------------------+
| tm |
+---------------------+
| 2017-03-22 12:10:00 |
+---------------------+
六、布尔bool或boolean=tinyint(1)
A value of zero is considered false,nonzero values are considered true.
示例:
mysql> create table t7(num bool);
mysql> insert into t7 values(true);
mysql> insert into t7 values(false);
mysql> insert into t7 values(123);
mysql> insert into t7 values(1);
mysql> insert into t7 values(0);
mysql> insert into t7 values(128); #范围在-128~127
ERROR 1264 (22003): Out of range value for column 'num' at row 1
mysql> select * from t7;
+------+
| num |
+------+
| 1 |
| 0 |
| 123 |
| 1 |
| 0 |
+------+
七、位
位主要是用来存放二进制数,select查询默认显示10进制,可以使用bin()、hex()函数来进行查询
bin()---显示二进制格式
hex()---显示十六进制格式
示例:
mysql> create table t7(id bit(4));
mysql> insert into t7 values(2);
mysql> insert into t7 values(13);
mysql> select bin(id),hex(id) from t7;
+---------+---------+
| bin(id) | hex(id) |
+---------+---------+
| 10 | 2 |
| 1101 | D |
+---------+---------+
MySQL之数据类型(常用)的更多相关文章
- MySQL复习(二)MySQL基本数据类型
MySQL基本数据类型 常用的字段类型大致可以分为数值类型.字符串类型.日期时间类型三大类 1. 数值类型 数值类型可以分为整型.浮点型.定点型三小类. 1.1 整型 (tiny:极小的, small ...
- MySQL数据库操作常用命令
MySQL数据库操作常用命令DOS连接数据库1.安装MySQL配置好环境2.运行cmd命令net start mysql3.找到mysql文件根目录输入命令mysql -h localhost -u ...
- { MySQL基础数据类型}一 介绍 二 数值类型 三 日期类型 四 字符串类型 五 枚举类型与集合类型
MySQL基础数据类型 阅读目录 一 介绍 二 数值类型 三 日期类型 四 字符串类型 五 枚举类型与集合类型 一 介绍 存储引擎决定了表的类型,而表内存放的数据也要有不同的类型,每种数据类型都有自己 ...
- MySQL的数据类型和建库策略详解
无论是在小得可怜的免费数据库空间或是大型电子商务网站,合理的设计表结构.充分利用空间是十分必要的.这就要求我们对数据库系统的常用数据类型有充分的认识.下面我就将我的一点心得写出来跟大家分享. 一.数字 ...
- Mysql 常见数据类型及约束
Mysql 常见数据类型及约束 最近在跟几个不太懂技术的同事(哈哈, 其实我也不懂), 要整一个数据库项目, 然后前端, 后端, 都没有像样的, 数据输出还不是由我们控制.... 这可难受了, 然后总 ...
- mysql数据库管理、常用命令及函数(10.10 第十八天)
数据库管理: MYSQL 轻量级数据库,适用于中小型企业,性能好,开源的(免费的) MSSQL 微软开发的,需要安装在NT系统中,不支持跨平台,适用于中大型企业 ACCESS 小巧方便,适用于小型企业 ...
- Mysql基础(三):MySQL基础数据类型、完整性约束、sql_mode模式
目录 2.MySQL基础数据类型.完整性约束.sql_mode模式 1. MySQL常用数据类型 2. 完整性约束 3. MySQL的sql_mode模式说明以及设置 2.MySQL基础数据类型.完整 ...
- 数据库02 /MySQL基础数据类型、完整性约束、sql_mode模式
2.MySQL基础数据类型.完整性约束.sql_mode模式 目录 2.MySQL基础数据类型.完整性约束.sql_mode模式 1. MySQL常用数据类型 MySQL常用数据类型预览 1. 1 数 ...
- 深入MySQL(二):MySQL的数据类型
前言 对于MySQL中的数据类型的选择,不同的数据类型看起来可能是相同的效果,但是其实很多时候天差地别. 本章从MySQL中的常用类型出发,结合类型选择的常见错误,贯彻MySQL的常用类型选择. 常用 ...
- mysql 登录及常用命令
一.mysql服务的启动和停止 mysql> net stop mysql mysql> net start mysql 二.登陆mysql mysql> 语法如下: mysql - ...
随机推荐
- Kubernetes运维生态-Heapster分析
Heapster在Kubernetes的运维生态中如下:集群的容器的监控数据收敛汇聚层 heapster1.0版本后内部分为event和metric两个进程,可制作为两个docker镜像部署为两个独立 ...
- SpringMvc的运行流程
一.先用文字描述 1.用户发送请求到DispatchServlet 2.DispatchServlet根据请求路径查询具体的Handler 3.HandlerMapping返回一个HandlerExc ...
- 局域网里连接mysql服务器,其他人连接自己的mysql服务器
应用场景: 自己在自己的机器上开发网站,同事也要和我一起开发,就两个人,我自己的机器当做服务器,让他直接连我的数据库,看我的项目就行了,并且用svn进行开发,相当不错 问题: 怎样在局域网里,其他人 ...
- Java8中 Parallel Streams 的陷阱 [译]
译注:文本有所精简和意译 原文链接 : Java Parallel Streams Are Bad for Your Health!原作者:OLEG SHELAJEV 翻译:Hason 转载请保留相关 ...
- wemall doraemon中Android app商城系统向指定URL发送GET方法的请求代码
URL的openConnection()方法将返回一个URLConnection对象,该对象表示应用程序和 URL 之间的通信链接.程序可以通过URLConnection实例向该URL发送请求.读取U ...
- 2431: [HAOI2009]逆序对数列
2431: [HAOI2009]逆序对数列 Time Limit: 5 Sec Memory Limit: 128 MBSubmit: 954 Solved: 548[Submit][Status ...
- 自定义 Layout布局 UICollectionViewLayout
from: http://www.tuicool.com/articles/vuyIriN 当我们使用系统自带的UICollectionViewFlowLayout无法实现我们的布局时,我们就可以 ...
- Yii2 Pjax 与 ActionForm ,不刷新提交数据
<?php yii\widgets\Pjax::begin(['id'=>'phoneDetail']);?> <?php $form = ActiveForm::begin( ...
- JetBrains套装免费学生授权申请(IntelliJ, WebStorm...)
IntelliJ作为一款强大的Java开发IDE,售价自然也不会低.但是对于学生或教师来说,JetBrains开发工具免费提供给学生和教师使用.而且取得一次授权后只需要使用相同的 JetBrains ...
- Linux上SQL及MYSQL简单操作
Linux上检查MYSQL是否安装: $ sudo service mysql start Ubuntu Linux安装配置MYSQL: $ sudo apt-get install mysql-se ...