原文:mysql基础之基本数据类型

列类型学习

mysql三大列类型

整型

Tinyint/ smallint/ mediumint/int/ bigint(M) unsigned zerofill

字符串型

Char(M)

Varchar(M)

Text 文本类型

日期时间类型

Date 日期

Time 时间

Datetime 时间时间类型

Year 年类型

整形:

整型系列所占字节与存储范围的关系.

定性: 占字节越多,存储范围越大.

下图: 是具体的数字分析

Tinyint 1个字节 8个位  0 - 2^8-1  ,  0-255

-2^7 ----> +2^7-1

分析:

Smallint 2个字节 , 16位  0----2^16-1 = 65535

-2^15 ---> +2^15-1, -32768 -> 32767

一般而言,设某类型 N字节

N字节 , 8N位.

0 ----> 2^8N-1

-2^(8N-1)  ---> +2^(8N-1) -1;

对于int型 : 占的字节越多,存储的范围也越大.

整型系统的可选参数 : XXint(M)  unsigned zerofill

例: age tinyint(4) unsigned ,或者  stunum smallint(6) zerofill;

Unsigned: 代表此列为无符号类型, 会影响到列的存储范围. (范围从0开始)

(不加unsinged, 则该列默认是有符号类型,范围从负数开始)

Zerofill: 代表0填充, 即: 如果该数字不足参数M位, 则自动补0, 补够M位.

1: 如果没有zerofill属性, 单独的参数M,没有任何意义.

2:如果设置某列为zerofill,则该列已经默认为 unsigned,无符号类型.

小数型

Float(M,D),decimal(M,D)

M叫"精度" ---->代表"总位数",而D是"标度",代表小数位.(小数右边的位数)

浮点数占多大的空间呢

答: float 能存10^38 ,10^-38

如果M<=24, 点4个字节,否则占8字节

用来表示数据中的小数,除了float---浮点.

还有一种叫定点decimal,定点是把整数部分, 和小数部分,分开存储的.

比float精确,他的长度是变化的.

空间上的区别:

Float(M,D), M<=24, 4个字节, 24 <M <=53, 8个字节

Decimal () ,变长字节.

区别: decimal比float精度更高, 适合存储货币等要求精确的数字,

见下例:

字符串性:

Mysql 字符串类型

Char 定长类型

Char(M)  , M 代表宽度, 0<=M<=255之间

例:Char(10)  ,则能输入10个字符.

Varchar 变长类型

Varchar(M), M代表宽度, 0<=M<=65535(以ascii字符为例,utf822000左右)

0000000000

00\0\0\0\0\0 (char型,如果不够M个字符,内部用空格补齐,取出时再把右侧空格删掉)

注:这意味着,如果右侧本身有空格,将会丢失.

通过concat函数可以验证!

M 代表字符长度,和是否是汉字和字母无关。

Blob,是二进制类型,用来存储图像,音频等二进制信息.

意义: 2进制,0-255都有可能出现.

Blob在于防止因为字符集的问题,导致信息丢失.

比如:一张图片中有0xFF字节, 这个在ascii字符集认为非法,在入库的时候,被过滤了.

enum选择一个,set选择多个

日期时间类型

Year 年(1字节)    95/1995,  [1901-2155],

在insert时,可以简写年的后2位,但是不推荐这样.

[00-69] +2000

[70-99] + 1900,

即: 填2位,表示 1970 - 2069

Date 日期  1998-12-31

范围: 1000/01/01 ,9999/12/31

Time 时间  13:56:23

范围: -838:59:59 -->838:59:59

datetime 时期时间  1998-12-31 13:56:23

范围: 1000/01//01 00:00:00  ---> 9999:12:31 23:59:59

timestamp

时间戳:

是1970-01-01 00:00:00 到当前的秒数.

一般存注册时间,商品发布时间等,并不是用datetime存储,而是用时间戳.

因为datetime虽然直观,但计算不便.


最新文章

  1. Gps与地图坐标转换
  2. Java Hour 45 Hibernate ( 2 )
  3. 修改Tomcat的网站根目录
  4. 多线程Java Socket编程示例(转)
  5. oracle存储过程异常捕获
  6. find查找命令
  7. 菜单栏—View(视图)菜单
  8. Java I/O---概述
  9. electron 学习笔记
  10. ORACLE复制表结构
  11. Spring-framework
  12. 用echarts写的multiple-trees demo
  13. 梯有N阶,上楼可以一步上一阶,也可以一步上二阶。编写一个程序,计算共有多少中不同的走法?
  14. JavaAndroid开发部分API
  15. 【XSY2745】装饰地板 状压DP 特征多项式
  16. nodejs 支付宝app支付
  17. leetcode — two-sum-ii-input-array-is-sorted
  18. springMVC和json整合配置方法
  19. SQL Server 的字段不为NULL时唯一
  20. JS 字符串切割成数组

热门文章

  1. hdu 5076 最小割灵活运用
  2. Initialising Memories
  3. Android GPS获取当前经纬度坐标
  4. Pro Aspnet MVC 4读书笔记(4) - Working with Razor
  5. Ajax 实现无刷新页面
  6. android_线
  7. CentOS 7 下安装 LEMP 服务(nginx、MariaDB/MySQL 和 php)
  8. git 如何让单个文件回退到指定的版本
  9. ubuntu下一个rootusername入口mysql,如何查看username和password,如何改变rootpassword
  10. 【LaTeX排版】LaTeX纸排版&amp;lt;两&amp;gt;