当前位置: 首页 > 编程日记 > 正文

MySQL数据类型

--------MySQL常用数据类型概括:

#1. 数字:整型:tinyint  int  bigint小数:float :在位数比较短的情况下不精准double :在位数比较长的情况下不精准decimal:(如果用小数,则用推荐使用decimal)精准-----------内部原理是以字符串形式去存

#2. 字符串:char10):简单粗暴,浪费空间,存取速度快root存成root000000varchar:精准,节省空间,存取速度慢sql优化:创建表时,定长的类型往前放,变长的往后放比如性别           比如地址或描述信息>255个字符,超了就把文件路径存放到数据库中。比如图片,视频等找一个文件服务器,数据库中只存路径或url。#3. 时间类型:最常用:datetime#4. 枚举类型与集合类型enum 和set

一、整数类型

作用:存储年龄、等级、id、各种号码等

========================================tinyint(n) unsigned zerofill小整数,数据类型用于保存一些范围的整数数值范围:有符号:-128127无符号:0~ 255PS: MySQL中无布尔值,使用tinyint(1)构造。========================================int(n) unsigned zerofill整数,数据类型用于保存一些范围的整数数值范围:有符号:-21474836482147483647无符号:0~ 4294967295========================================bigint(n) unsigned zerofill大整数,数据类型用于保存一些范围的整数数值范围:有符号:-92233720368547758089223372036854775807无符号:0~  18446744073709551615

ps:tinyint int bigint默认都是有符号的,int类型后面的存储是显示宽度,而不是存储宽度。

二、浮点型

作用:存储薪资、身高、体重、体质参数等

-------------------------FLOAT-------------------
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-----------------------
DOUBLE[(M,D)] [UNSIGNED] [ZEROFILL]#参数解释: 双精度浮点数(非准确小数值),M是全长,D是小数点后个数。M最大值为255,D最大值为30#有符号:-1.7976931348623157E+308 to -2.2250738585072014E-3082.2250738585072014E-308 to 1.7976931348623157E+308#无符号:2.2250738585072014E-308 to 1.7976931348623157E+308#精确度:****随着小数的增多,精度比float要高,但也会变得不准确 ****======================================
--------------------DECIMAL------------------------
decimal[(m[,d])] [unsigned] [zerofill]#参数解释:准确的小数值,M是整数部分总个数(负号不算),D是小数点后个数。 M最大值为65,D最大值为30。#精确度:**** 随着小数的增多,精度始终准确 ****对于精确数值计算时需要用此类型decaimal能够存储精确值的原因在于其内部按照字符串存储。

三、日期类型

作用:存储用户注册时间,文章发布时间,员工入职时间,出生时间,过期时间等

语法:YEARYYYY(1901/2155)DATEYYYY-MM-DD(1000-01-01/9999-12-31)TIMEHH:MM:SS('-838:59:59'/'838:59:59'DATETIMEYYYY-MM-DD HH:MM:SS(1000-01-01 00:00:00/9999-12-31 23:59:59TIMESTAMPYYYYMMDD HHMMSS(1970-01-01 00:00:00/2037 年某时)

(1)year

mysql> create table t8(born_year year);#无论year指定何种宽度,最后都默认是year(4)
Query OK, 0 rows affected (0.03 sec)#插入失败,超出范围(1901/2155)
mysql>  insert into t8 values->  (1900),-> (1901),->  (2155),->  (2156);
ERROR 1264 (22003): Out of range value for column 'born_year' at row 1mysql> select * from t8;
Empty set (0.01 sec)mysql> insert into t8 values-> (1905),-> (2018);
Query OK, 2 rows affected (0.00 sec) #插入记录成功
Records: 2  Duplicates: 0  Warnings: 0mysql> select * from t8;
+-----------+
| born_year |
+-----------+
|      1905 |
|      2018 |
+-----------+
rows in set (0.00 sec)

(2)data、year、datatime

#创建t9表
mysql> create table t9(d date,t time,dt datetime);
Query OK, 0 rows affected (0.06 sec)#查看表的结构
mysql> desc t9;
+-------+----------+------+-----+---------+-------+
| Field | Type     | Null | Key | Default | Extra |
+-------+----------+------+-----+---------+-------+
| d     | date     | YES  |     | NULL    |       |
| t     | time     | YES  |     | NULL    |       |
| dt    | datetime | YES  |     | NULL    |       |
+-------+----------+------+-----+---------+-------+
rows in set (0.14 sec)# 调用mysql自带的now()函数,获取当前类型指定的时间 如下结构
mysql> insert into t9 values(now(),now(),now());
Query OK, 1 row affected, 1 warning (0.01 sec)mysql> select * from t9;
+------------+----------+---------------------+
| d          | t        | dt                  |
+------------+----------+---------------------+
| 2018-06-09 | 09:35:20 | 2018-06-09 09:35:20 |
+------------+----------+---------------------+
row in set (0.00 sec)

四、字符类型

#官网:https://dev.mysql.com/doc/refman/5.7/en/char.html
#注意:char和varchar括号内的参数指的都是字符的长度#char类型:定长,简单粗暴,浪费空间,存取速度快字符长度范围:0-255(一个中文是一个字符,是utf8编码的3个字节)存储:存储char类型的值时,会往右填充空格来满足长度例如:指定长度为10,存>10个字符则报错,存<10个字符则用空格填充直到凑够10个字符存储检索:在检索或者说查询时,查出的结果会自动删除尾部的空格,除非我们打开pad_char_to_full_length SQL模式(设置SQL模式:SET sql_mode = 'PAD_CHAR_TO_FULL_LENGTH';查询sql的默认模式:select @@sql_mode;)#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)检索:尾部有空格会保存下来,在检索或者说查询时,也会正常显示包含空格在内的内容

验证:

验证之前了解两个函数:

length():查看字节数
char_length():查看字符数

***************char填充空格来满足固定长度,但是在查询时却会很不要脸地删除尾部的空格(装作自己好像没有浪费过空间一样),然后修改sql_mode让其现出原形。

# 创建t1表,分别指明字段x为char类型,字段y为varchar类型
mysql> create table t1(x char(5),y varchar(4));
Query OK, 0 rows affected (0.16 sec)# char存放的是5个字符,而varchar存4个字符
mysql>  insert into t1 values('你瞅啥 ','你瞅啥 ');
Query OK, 1 row affected (0.01 sec)# 在检索时char很不要脸地将自己浪费的2个字符给删掉了,装的好像自己没浪费过空间一样,而varchar很老实,存了多少,就显示多少
mysql> select x,char_length(x),y,char_length(y) from t1;
+-----------+----------------+------------+----------------+
| x         | char_length(x) | y          | char_length(y) |
+-----------+----------------+------------+----------------+
| 你瞅啥    |              3 | 你瞅啥     |              4 |
+-----------+----------------+------------+----------------+
row in set (0.02 sec)#略施小计,让char现原形mysql> SET sql_mode = 'PAD_CHAR_TO_FULL_LENGTH';
Query OK, 0 rows affected (0.00 sec)#查看当前mysql的mode模式
mysql> select @@sql_mode;
+-------------------------+
| @@sql_mode              |
+-------------------------+
| PAD_CHAR_TO_FULL_LENGTH |
+-------------------------+
row in set (0.00 sec)#原形毕露了吧。。。。
mysql> select x,char_length(x) y,char_length(y) from t1;
+-------------+------+----------------+
| x           | y    | char_length(y) |
+-------------+------+----------------+
| 你瞅啥      |    5 |              4 |
+-------------+------+----------------+
row in set (0.00 sec)# 查看字节数
#char类型:3个中文字符+2个空格=11Bytes
#varchar类型:3个中文字符+1个空格=10Bytes
mysql> select x,length(x),y,length(y) from t1;
+-------------+-----------+------------+-----------+
| x           | length(x) | y          | length(y) |
+-------------+-----------+------------+-----------+
| 你瞅啥      |        11 | 你瞅啥     |        10 |
+-------------+-----------+------------+-----------+
row in set (0.02 sec)

五、枚举类型和集合

枚举:enum 单选 只能在给定的范围内选一个值,如性别 sex 男male/女female

集合:set 多选 在给定的范围内可以选择一个或一个以上的值(爱好1,爱好2,爱好3...)

mysql> create table consumer(-> id int,-> name varchar(50),-> sex enum('male','female','other'),-> level enum('vip1','vip2','vip3','vip4'),#在指定范围内,多选一-> fav set('play','music','read','study') #在指定范围内,多选多-> );
Query OK, 0 rows affected (0.03 sec)mysql> insert into consumer values-> (1,'赵云','male','vip2','read,study'),-> (2,'赵云2','other','vip4','play');
Query OK, 2 rows affected (0.00 sec)
Records: 2  Duplicates: 0  Warnings: 0mysql> select * from consumer;
+------+---------+-------+-------+------------+
| id   | name    | sex   | level | fav        |
+------+---------+-------+-------+------------+
|    1 | 赵云    | male  | vip2  | read,study |
|    2 | 赵云2   | other | vip4  | play       |
+------+---------+-------+-------+------------+
rows in set (0.00 sec)

转载于:https://www.cnblogs.com/fengchong/p/9800472.html

相关文章:

L1-047 装睡 (结构体解决)

L1-047 装睡 (10 分) 你永远叫不醒一个装睡的人 —— 但是通过分析一个人的呼吸频率和脉搏&#xff0c;你可以发现谁在装睡&#xff01;医生告诉我们&#xff0c;正常人睡眠时的呼吸频率是每分钟15-20次&#xff0c;脉搏是每分钟50-70次。下面给定一系列人的呼吸频率与脉搏&am…

sum_series() 求一列数的指定个数的数和(5个数字的和)

1 #include <stdio.h>2 #include <stdarg.h>3 /*用sum_series() 求一列数的指定个数的数和(5个数字的和)*/4 double sum_series(int num, ...);5 6 int main()7 {8 double s;9 s sum_series(5, 0.5, 0.25, 0.125, 0.06254, 2.0); 10 printf("Sum…

oracle创建用户名授权,oracle创建用户及授权创建表

----Oracle 用户、对象权限、系统权限--建立表空间和用户的步骤&#xff1a;用户建立&#xff1a;create user 用户名 identified by "密码";授权&#xff1a;grant create session to 用户名;grant create table to 用户名;grant create tablespace to 用户名;gra…

过滤器、拦截器、aop的先后顺序和作用范围&拦截器preHandle(),postHandle(),afterComplation()方法执行顺序

在Spring框架中,过滤器(Filter)、拦截器(Interceptor)和面向切面编程(AOP)都是用于处理请求和处理流程的组件,但它们的作用范围和触发时机有所不同。下面我会解释这三者的先后顺序和作用范围。执行顺序:请注意,这个顺序可能因具体的配置和使用的技术而有所不同。在实际应用中,建议根据项目的具体需求来合理配置和使用这些组件。拦截器执行流程图:实现拦截器需要实现这个接口,这个 接口中有三个默认方法,这三个方法的执行顺序:我们实现接口然后重写这三个方法,就会在对应的时机被自动执行。这里就是调用处理

[IoC容器Unity]第四回:使用范例

1.引言  前面几个章节介绍了Unity的基本使用&#xff0c;主要分为程序和配置文件两种方法的使用&#xff0c;可以参考一下链接&#xff0c; [IoC容器Unity]第一回&#xff1a;Unity预览[IoC容器Unity]第二回&#xff1a;Lifetime Managers生命周期[IoC容器Unity]第三回&#x…

Zookeeper概要、协议、应用场景

Zoopkeeper提供了一套很好的分布式集群管理的机制,就是它这种基于层次型的目录树的数据结构并对树中的节点进行有效管理,从而可以设计出多种多样的分布式的数据管理模型,作为分布式系统的沟通调度桥梁。

L1-056 猜数字 (结构体解决)

L1-056 猜数字 (20 分) 一群人坐在一起&#xff0c;每人猜一个 100 以内的数&#xff0c;谁的数字最接近大家平均数的一半就赢。本题就要求你找出其中的赢家。 输入格式&#xff1a; 输入在第一行给出一个正整数N&#xff08;≤104&#xff09;。随后 N 行&#xff0c;每行给…

不同的source control下配置DiffMerge

TFS&#xff1a; 1. 打开Option -> Source Control -> Visual Studio TFS -> Configure User Tools; 2. 添加 .*, Compare, C:\Program Files (x86)\SourceGear\DiffMerge\DiffMerge.exe, /title1%6 /title2%7 %1 %2; 3. 添加 .*, Merge, C:\Program Files (x86)\Sour…

下载oracle修复补丁下载,Oracle数据库修复工具下载_FROMBYTE Reconstructor for Oracle官方版下载[修复软件]-下载之家...

FROMBYTE Reconstructor for Oracle(Oracle数据库修复工具)官方版是一款专为Oracle的数据库进行修复软件&#xff0c;可以通过Oracle数据库修复工具软件创建一个修复区域&#xff0c;随后对数据库所在的位置扫描&#xff0c;将扫描的结果显示在主区域&#xff0c;让您可以查看哪…

SEO查询指令,非常值得你收藏!

用好搜索引擎一些特殊指令&#xff0c;是干SEO这行的一个基本功。初步整理了10个功能&#xff0c;单独使用是最基本的能力&#xff0c;如果综合使用&#xff0c;你会发现搜索的奥妙无穷。 1. site:  某个特定网站收录情况  比如site:www.baidu.com 2. cache:  上一次搜索…

GITHup的使用

一个源码管理工具&#xff0c;由于不擅长敲GIt命令&#xff0c;还不太喜欢用英文版本的软件&#xff0c;所以想办法用中文版的图形工具步骤如下&#xff1a; 下载了GIT64位&#xff0c;安装&#xff0c;下载了TortoiseGit和TortoiseGit中文语言包&#xff0c;先后安装。然后设置…

debug:g2o cmake时报错“Qt5 not found. Install it and set Qt5_DIR accordingly

** debug&#xff1a;g2o cmake时报错“Qt5 not found. Install it and set Qt5_DIR accordingly” ** 完整报错&#xff1a; ubuntu:~/WorkSpace/g2o/build$ cmake …/ – Compiling on Unix – Found CHOLMOD and its dependencies – Compiling with OpenGL support – C…

oracle表中怎么去重复,Oracle里去掉表里组合字段重复的记录步骤是什么呢?

当设计表的时候没有建组合字段唯一约束&#xff0c;以后需要增加这一约束时&#xff0c;却发现表里已经有了很多重复记录了。请看看我用的去掉表里组合字段重复的记录方法&#xff1a;假设原始表名为source_table,字段名1为field_name1,字段名2为field_name2。(当然稍加修改也可…

Windows Server 2012

安装Windows Server 2012之后&#xff0c;为了使用的方便性、性能&#xff0c;作如下配置&#xff1a; 一、方便使用&#xff1a; 1、启动时不需要按CtrlAltDel&#xff1a; 控制面板|管理工具|本地安全设置&#xff0c;弹出本地安全设置窗口&#xff0c;然后选择“安全设置…

从网站上扒网页,保存为file文件格式

保存下来的页面总是有部分特效缺失&#xff0c;可是文件包里已经有好几个js文件了。  例如想保存易迅的搜索页面&#xff0c;条件筛选栏的按钮全部失效了&#xff0c;按钮-更多、多选等 都没有反应&#xff0c;搜索结果的鼠标悬浮显示完整信息也没有了。 在 Chrome 地址栏中键…

CSDN:新的开始

这里写自定义目录标题欢迎使用Markdown编辑器新的改变功能快捷键合理的创建标题&#xff0c;有助于目录的生成如何改变文本的样式插入链接与图片如何插入一段漂亮的代码片生成一个适合你的列表创建一个表格设定内容居中、居左、居右SmartyPants创建一个自定义列表如何创建一个注…

oracle直查和call哪个更快,让oracle跑的更快1读书笔记二

当前位置:我的异常网 数据库 <>读书笔记二<>读书笔记二www.myexceptions.net 网友分享于&#xff1a;2013-08-23 浏览&#xff1a;9次<>读书笔记21 绑定变量1)硬分析和软分析硬分析需要判断是否已经在共享池中&#xff0c;如果有的话&#xff0c;则直接拿…

WordPress 开启 Gzip 为网页加载提速减少响应时间

2019独角兽企业重金招聘Python工程师标准>>> 大家都晓得&#xff0c;开启Gzip能极大地压缩文本数据的体积。对于使用 WordPress 的博主来说&#xff0c;开启服务器的GZip压缩是一个为博客加速的好方法。GZip可对多种类型的文 件进行压缩&#xff0c;对于 CSS&#x…

20180829-Java多线程编程

Java 多线程编程 Java给多线程编程提供了内置的支持。一个多线程程序包含两个或多个能并发运行的部分。 程序的每一部分都称作一个线程&#xff0c;并且每个线程定义了一个独立的执行路径。 多线程是多任务的一种特别的形式。多线程比多任务需要更小的开销。 这里定义和线程相关…

b-blkid查看磁盘设备文件系统类型

blkid命令对查询设备上所采用文件系统类型进行查询。blkid主要用来对系统的块设备&#xff08;包括交换分区&#xff09;所使用的文件系统类型、LABEL、UUID等信息进行查询 改命令存在于util-linux-2.23.2-26.el7.x86_64软件包之中 常用命令展示 blkid查询所有设备的文件系统…

与后台交互方法一 ——Ajax

一、Ajax&#xff1a;为无刷新读取服务器端数据&#xff0c;常用在用户注册、在线聊天室等。 使用Ajax读取数据时有以下几点需要注意&#xff1a; 1.字符集编码前后台要一致&#xff0c;否则前台显示的数据为乱码。 2.使用随机数或时间清除缓存、阻止缓存&#xff0c;防止服务器…

php复选框关联数据库字段,通过php将复选框中的多个值插入数据库

|我想将此表单值插入到datanase中&#xff1a;Brand 1Brand 2Brand 3Brand 4Brand 5这些文本框是通过php从数据库中的表中获取的&#xff0c;并且可能是Variable我想以这种格式插入数据库如果检查品牌1&#xff0c;则$ brand \“ 1&#xff0c;\”;最后像这样&#xff1a;inse…

WPF中的容器控件——Grid

网格布局 123123123123123123123123123123123123123123123123123123123123123123123123123123112312312312312312312312312312312312312312312312312312312312312312 123123实际应用中应该少不了网格布局&#xff0c;grid布局的特点&#xff1a; 1.每个grid中可以放多个控件&am…

h-hdparm打开关闭磁盘cache

查看磁盘型号 hdparm -I /dev/sde 查看磁盘缓存情况 hdparm -W /dev/sdb 打开或者关闭磁盘cache hdparm -W 0 /dev/sdb关闭 hdparm -W 1 /dev/sdb打开

linux diff 补丁文件夹,LINUX下制作补丁文件 diff,patch

diff(differential)功能说明&#xff1a;比较文件的差异。语  法&#xff1a;diff [-abBcdefHilnNpPqrstTuvwy][-;][-C ;][-D ;][-I ;][-S ;][-W ;][-x ;][-X ;][--help][--left-column][--suppress-common-line][文件或目录1][文件或目录2]补充说明&#xff1a;diff以逐行的…

连通性2 无向图的双连通 bcc

待续。。。转载于:https://www.cnblogs.com/assult/p/3312457.html

网络规划设计培训与方案集下载

http://down.51cto.com/data/96887为OSPF城域网部署专题http://down.51cto.com/data/565799华为、H3C、神码等的一些关于网络规划设计的PPT资料&#xff0c;有技术性的&#xff0c;有理论的&#xff0c;有技术理论的。http://down.51cto.com/data/96885策略路由与路由策略原理培…

C语言标准库之strcat函数

2018-10-20C库函数strcat()函数的功能是实现字符串的拼接。其函数原型如下所示char *strcat(char *dest, const char *src) 1、参数说明 dest&#xff1a;指向目标数组&#xff0c;该目标包含看一个C字符串&#xff0c;且足够容纳追加之后的字符串。 src: 指向要追加的字…

设计模式——单例模式(Singleton)

保证一个类仅有一个实例&#xff0c;并提供一个访问它的全局访问点。——DP UML类图 模式说明 个人认为单例模式是所有设计模式中最为简单的一个模式&#xff0c;因为实现这个模式仅需一个类&#xff0c;而不像其他模式需要若干个类。这个模式中&#xff0c;需要注意的一点就是…

l-logger命令基本介绍

logger是一个shell命令接口&#xff0c;可以通过该接口使用Syslog的系统日志模块&#xff0c;还可以从命令行直接向系统日志文件写入一行信息 logger语法: 可以使用的相关命令 -d, --udp 使用数据报(UDP)而不是使用默认的流连接(TCP) -i, --id 逐行记录每一次logger的进程…