MySQL 数据类型

MySQL中定义数据字段的类型对你数据库的优化是非常重要的。
MySQL支持多种类型,大致可以分为三类:数值、日期/时间和字符串(字符)类型。

数值类型

MySQL支持所有标准SQL数值数据类型。
这些类型包括严格数值数据类型(INTEGER、SMALLINT、DECIMAL和NUMERIC),以及近似数值数据类型
(FLOAT、REAL和DOUBLE PRECISION)。
关键字INT是INTEGER的同义词,关键字DEC是DECIMAL的同义词。
BIT数据类型保存位字段值,并且支持MyISAM、MEMORY、InnoDB和BDB表。
作为SQL标准的扩展,MySQL也支持整数类型TINYINT、MEDIUMINT和BIGINT。下面的表显示了需要的
每个整数类型的存储和范围。

日期和时间类型

表示时间值的日期和时间类型为DATETIME、DATE、TIMESTAMP、TIME和YEAR。
每个时间类型有一个有效值范围和一个"零"值,当指定不合法的MySQL不能表示的值时使用"零"值。
TIMESTAMP类型有专有的自动更新特性,将在后面描述。

字符串类型

字符串类型指CHAR、VARCHAR、BINARY、VARBINARY、BLOB、TEXT、ENUM和SET。该节描述了这
些类型如何工作以及如何在查询中使用这些类型。
CHAR 和 VARCHAR 类型类似,但它们保存和检索的方式不同。它们的最大长度和是否尾部空格被保留等
方面也不同。在存储或检索过程中不进行大小写转换。
BINARY 和 VARBINARY 类似于 CHAR 和 VARCHAR,不同的是它们包含二进制字符串而不要非二进制字
符串。也就是说,它们包含字节字符串而不是字符字符串。这说明它们没有字符集,并且排序和比较基于
列值字节的数值值。

BLOB 是一个二进制大对象,可以容纳可变数量的数据。有 4 种 BLOB 类型:TINYBLOB、BLOB、
MEDIUMBLOB 和 LONGBLOB。它们区别在于可容纳存储范围不同。

有 4 种 TEXT 类型:TINYTEXT、TEXT、MEDIUMTEXT 和 LONGTEXT。对应的这 4 种 BLOB 类型,可存
储的最大长度不同,可根据实际情况选择。

MySQL 5.0 以上的版本: 
1、一个汉字占多少长度与编码有关: 
UTF-8:一个汉字=3个字节
GBK:一个汉字=2个字节
2、varchar(n) 表示 n 个字符,无论汉字和英文,Mysql 都能存入 n 个字符,仅是实际字节长度有所区别
3、MySQL 检查长度,可用 SQL 语言来查看:

select LENGTH(fieldname) from tablename

1、整型
取值范围如果加了 unsigned,则最大值翻倍,如 tinyint unsigned 的取值范围为(0~256)。
int(m) 里的 m 是表示 SELECT 查询结果集中的显示宽度,并不影响实际的取值范围,没有影响到显示的
宽度,不知道这个 m 有什么用。

2、浮点型(float 和 double) 
设一个字段定义为 float(5,3),如果插入一个数 123.45678,实际数据库里存的是 123.457,但总个数还以
实际为准,即 6 位。

3、定点数
浮点型在数据库中存放的是近似值,而定点类型在数据库中存放的是精确值。
decimal(m,d) 参数 m<65 是总个数,d<30 且 d<m 是小数位。

4、字符串(char,varchar,_text) 
char 和 varchar: 
** 1.char(n) 若存入字符数小于n,则以空格补于其后,查询之时再将空格去掉。所以 char 类型存储的字符串末尾不能有空格,varchar 不限于此。
** 2.char(n) 固定长度,char(4) 不管是存入几个字符,都将占用 4 个字节,varchar 是存入的实际字
符数 +1 个字节(n<=255)或2个字节(n>255),所以 varchar(4),存入 3 个字符将占用 4 个字节。
** 3.char 类型的字符串检索速度要比 varchar 类型的快。
varchar 和 text: 
** 1.varchar 可指定 n,text 不能指定,内部存储 varchar 是存入的实际字符数 +1 个字节
(n<=255)或 2 个字节(n>255),text 是实际字符数 +2 个字节。
** 2.text 类型不能有默认值。
** 3.varchar 可直接创建索引,text 创建索引要指定前多少个字符。varchar 查询速度快于 text, 在都
创建索引的情况下,text 的索引似乎不起作用。

5.二进制数据(_Blob) 
** 1.BLOB和text存储方式不同,TEXT以文本方式存储,英文存储区分大小写,而Blob是以二进制方
式存储,不分大小写。
** 2._BLOB存储的数据只能整体读出。
** 3.TEXT可以指定字符集,BLOB不用指定字符集。

6.日期时间类型
若定义一个字段为timestamp,这个字段里的时间数据会随其他字段修改的时候自动刷新,所以这个数据
类型的字段可以存放这条记录最后被修改的时间。

数据库-数据类型介绍相关推荐

  1. mysql数据库邮箱什么类型_MySQL的数据类型介绍

    MySQL的数据类型介绍 发布时间:2020-06-01 20:57:09 来源:亿速云 阅读:154 作者:鸽子 由于Mysql独有的特性和实现细节对性能的影响是很明显的,因为做好Mysql数据库的 ...

  2. redis种类型对应java类型_Redis的五种基本数据类型介绍

    Redis作为缓存具有极其丰富的功能,比如计数器.好友关系以及排行榜等等.而Redis之所能够实现如此强大的功能,完全是依赖着它的基本数据结构.今天我们来看看Redis的五种基本的数据结构,分别是字符 ...

  3. MySql数据类型介绍

    对于刚开始学习MySql数据库的小伙伴们来说,MySql数据库有那些数据类型呢,在此我给大家总结介绍一下MySql数据库数据类型. MySql数据类型 数据类型一共有五大类分别是: 整数类型:BIT. ...

  4. 【Unity 3D游戏开发】在Unity使用NoSQL数据库方法介绍

    随着游戏体积和功能的不断叠加,游戏中的数据也变得越来越庞杂,这其中既包括玩家产生的游戏存档等数据,例如关卡数.金币等,也包括游戏配置数据,例如每一关的配置情况.尽管Unity提供了PlayerPref ...

  5. DB2日期时间型数据类型介绍

    作者:夏果果出处:博客2011-11-18 07:23 DB2日期时间型数据类型是DB2数据库中的数据类型之一,下面就为您分类介绍DB2日期时间型数据类型,希望对您能有所帮助-- DB2日期时间型数据 ...

  6. 13-企业网站数据库-企业介绍数据操作

    13-企业网站数据库-企业介绍数据操作 文章目录 13-企业网站数据库-企业介绍数据操作 项目描述 企业网站数据库操作要求如下: (1)任务描述 项目描述 随着互联网技术的日益成熟,企业网站有&quo ...

  7. MySQL的存储引擎及常用数据类型介绍

    1. MySQL中的数据库分类 2. MySQL中的存储引擎 MySQL中的数据用各种不同的技术存储在文件(或者内存)中.这些技术中的每一种技术都使用不同的存储机制.索引技巧.锁定水平并且最终提供不同 ...

  8. 图数据库Neo4j介绍

    1.图数据库Neo4j介绍 1.1 什么是图数据库(graph database) 随着社交.电商.金融.零售.物联网等行业的快速发展,现实社会织起了了一张庞大而复杂的关系网,传统数据库很难处理关系运 ...

  9. 第3节-Redis数据类型介绍以及应用

    第3节-Redis数据类型介绍以及应用 1.9大类型 String(字符类型) Hash(散列类型) List(列表类型) Set(集合类型) SortedSort(有序集合类型,简称zset) Bi ...

最新文章

  1. 安装kubernetes1.12.1的 dashboard v1.10 + Heapster
  2. tensorflow tfrecoder read write
  3. php源码 自定义字段,wordpress主题制作:设置自定义选项字段
  4. [转载] python numpy 总结
  5. 实现教科书图7.33的程序(另加孤立顶点台北)(两城市之间的最短路径模拟)
  6. 高通路由器(WIFI)芯片处理器IPQ4029介绍
  7. c语言随机抽取函数,Excel随机取值,给你三种解决方案
  8. MSDN,我告诉你——一个很棒的工具站
  9. 哪个平台的身份证实名认证接口服务比较靠谱?
  10. 如何获取阿里云服务器镜像
  11. 华硕Afudos更新bios方法介绍
  12. PLC实验:LED 数码显示控制
  13. 利用Python自动生成及发送Excel报表
  14. SG3525频率和占空比参数的选取
  15. opencv 简单的裂缝检测
  16. 详解 atoi 函数并模拟实现
  17. 求与下面谓词公式等值的前束范式_离散数学课后答案
  18. 天涯明月刀电视剧全集(1-40)
  19. 共享充电语音提醒功能如何实现?
  20. dirent d_type类型

热门文章

  1. 中奖人员信息向上滚动
  2. Codeforces 712C. Memory and De-Evolution
  3. 用Qemu模拟vexpress-a9 (四) --- u-boot引导kernel,用nfs挂载根文件系统
  4. Jquery Mobile设计Android通讯录第二章
  5. C++实现另一个猜数字游戏
  6. 大话设计模式—组合模式
  7. 手机浏览器无法获取COOKIE的原因
  8. (转) 淘淘商城系列——Redis五种数据类型介绍
  9. jQuery获取Table某列的值
  10. 如何开发Web应用程序(非网站)