首页 > 数据库 > mysql教程 > mysql数据类型有哪些

mysql数据类型有哪些

coldplay.xixi
发布: 2020-10-29 16:18:21
原创
24254 人浏览过

mysql数据类型有:1、数值类型;2、日期和时间类型;3、字符串类型是CHAR、VARCHAR、BINARY【二进制数据类型】、BLOB、TEXT【文本类型】、ENUM【枚举类型】和SET【数据集合】。

mysql数据类型有哪些

mysql数据类型有:

MySQL支持的数据类型在几类:数值类型,日期和时间类型和字符串(字符)类型。

数据类型:

   

注意:

  •   在定义字段是我们经常使用 num int(10) unsigned 这种写法,其中的 int(10) 并不是表示该字段会存储10个长度的数字。

  •   int(M) 表示的是数字显示的格式,并且只能在字段属性设置了zerofill时才有效。

  eg:

    tinyint(4) -- 实际存储值为2, 如果没有指定zerofill,查询得到的结果就是 2, 如果指定了zerofill,则查询结果就是 0002,左边使用0来进行填充;

zerofill属性:

  • 如果字段指定了zerofill属性,mysql会自动为字段加上UNSIGNED 属性。

  • 当涉及列表达式或UNION查询中时,ZEROFILL属性将被忽略

浮点型:

    Float(M,D)M为数字的位数,包含了整数部分和小数部分;D为小数部分,【D <= M-2】; 如果等于则整数部分为0,最大的值也就是0.99

     eg:

  •   Float(2,1) -- 表示一位整数和一位小数,eg:1.1

  •   Float(1,2) -- 语法错误,总共才1位 怎么可能有2位小数

关于默认值:

  • 默认值必须是一个常亮,不能函数或者表达式。例外:TIMESTAMP的默认值可以使用CURRENT_TIMESTAMP

  • BLOB and TEXT 不能设置默认值

如果一个列不明确的指出默认是是多少的情况下:

  • 如果数据库为strict mode 模式下,则会报错

  • 如果模式不处于strict mode模式,系统会根据类型来确认使用何种默认值

日期和时间格式:

  表示时间值的日期和时间类型是日期时间(DATATIME)、日期(DATA)、时间戳(TIMESTAMP)、时间(TIME)和年份(YEAR)。

   

  DATATIME范围: '1000-01-01 00:00:00' to '9999-12-31 23:59:59'

  DATA范围:'1000-01-01' to '9999-12-31'

  TIMESTAMP范围:'1970-01-01 00:00:01' UTC to '2038-01-19 03:14:07'

  TIME范围:'-838:59:59' to '838:59:59'

  YEAR范围:year(4) --- 1901~2155; year(2) --- 00~99

  TIMESTAMP: 时间戳列显示在相同的格式为DATETIME列。换句话说,显示宽度固定为19个字符,格式是'YYYY-MM-DD HH:MM:SS'。

  TIMESTAMP数据类型提供自动初始化和更新。但是只能有一列默认值和更新是 指定为CURRENT_TIMESTAMP

  1、自动初始化和自动更新 eg : ts TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP

  2、只有自动初始化; eg:ts TIMESTAMP DEFAULT CURRENT_TIMESTAMP

  3、只有自动更新; eg:ts TIMESTAMP DEFAULT 0 ON UPDATE CURRENT_TIMESTAMP

  4、都没有; eg:ts TIMESTAMP DEFAULT 0

字符串类型:

  字符串类型是CHAR、VARCHAR、BINARY【二进制数据类型】、BLOB、TEXT【文本类型】、ENUM【枚举类型】和SET【数据集合】。

  char和varchar的区别:存储长度的区别在于最大长度和是否保留空格;

    char会保留空格,varchar不会保留空格

    char为 0~ 255;  varchar为 0 ~ 65535

  

  ENUM: 枚举是一个字符串对象从中明确列举了在创建表时列规范的允许值的列表中选择一个值。【当插入值不能和列表的值惊醒匹配时,默认是最大索引值】

 , ,
登录后复制
numbers ENUM(&#39;0&#39;,&#39;1&#39;,&#39;2&#39;)
登录后复制
mysql> INSERT INTO t (numbers) VALUES(2),(&#39;2&#39;),(&#39;3&#39;);mysql> SELECT * FROM t;+---------+
| numbers |
+---------+
| 1       |
| 2       |
| 2       |
+---------+
登录后复制

  SET: 集是一个对象,该对象可以有零个或多个值的字符串,其中每个必须从列表中选择允许创建表时指定的值。【当插入值不能和列表的值经行匹配时,MYSQL会忽略列表中不存在的值

1 CREATE TABLE myset (col SET(&#39;a&#39;, &#39;b&#39;, &#39;c&#39;, &#39;d&#39;));2 3 INSERT INTO myset (col) VALUES (&#39;a,d&#39;), (&#39;d,a&#39;), (&#39;a,d,a&#39;), (&#39;a,d,d&#39;), (&#39;d,a,d&#39;);
登录后复制

  从定义中可以看出 ENUM和SET的区别在于值是定义时指定的值中的一个还是多个。还有就是在插入值在列表中不存在的表现不一样。

更多相关免费学习推荐:mysql教程(视频)

以上是mysql数据类型有哪些的详细内容。更多信息请关注PHP中文网其他相关文章!

相关标签:
来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板