Heim > Datenbank > MySQL-Tutorial > Hauptteil

mysql数据类型有哪些

coldplay.xixi
Freigeben: 2020-10-29 16:18:21
Original
24002 人浏览过

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

 , ,
Nach dem Login kopieren
numbers ENUM('0','1','2')
Nach dem Login kopieren
mysql> INSERT INTO t (numbers) VALUES(2),('2'),('3');mysql> SELECT * FROM t;+---------+
| numbers |
+---------+
| 1       |
| 2       |
| 2       |
+---------+
Nach dem Login kopieren

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

1 CREATE TABLE myset (col SET('a', 'b', 'c', 'd'));2 3 INSERT INTO myset (col) VALUES ('a,d'), ('d,a'), ('a,d,a'), ('a,d,d'), ('d,a,d');
Nach dem Login kopieren

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

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

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

Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage
Über uns Haftungsausschluss Sitemap
Chinesische PHP-Website:Online-PHP-Schulung für das Gemeinwohl,Helfen Sie PHP-Lernenden, sich schnell weiterzuentwickeln!