mysql数据类型属性总结(方便大家建数据库设定类型参考)
MySQL(二)数据库数据类型详解
MySQL(⼆)数据库数据类型详解 序⾔ 今天去健⾝了,感觉把⾝体练好还是不错的,闲话不多说,把这个数据库所遇到的数据类型今天统统在这⾥讲清楚了,以后在看到什么数据类型,咱度应该认识,下⾯就跟着我的节奏去把这个拿下吧。
---WZY⼀、数据类型 MySQL的数据类型有⼤概可以分为5种,分别是整数类型、浮点数类型和定点数类型、⽇期和时间类型、字符串类型、⼆进制类型。
现在可以来看看你对这5种类型的熟悉程度,哪个看起来懵逼了,那就说明⾃⼰哪个不熟悉,不理解。
注意:整数类型和浮点数类型可以统称为数值数据类型,这不难理解。
数值数据类型 整数类型:TINYINT、SMALLINT、MEDIUMINT、INT、BIGINT 浮点数类型:FLOAT、DOUBLE 定点⼩数:DECIMAL ⽇期/时间类型 YEAR、TIME、DATE、DATETIME、TIMESTAMP 字符串类型 CHAR、VARCHAR、TEXT、ENUM、SET等 ⼆进制类型 BIT、BINARY、VARBINARY、BLOB 1、整数类型 不管你学什么语⾔,在基础⽅⾯,都应该知道 1个字节= 8位⼆进制数。
每个类型的取值范围也就能够知道,⽐如TINYINT占⽤1个字节,也就是8位,2的8次⽅减1等于255,也就是说如果代表没符号的整数,该取值范围为0~255,如果是有符号的,最⾼位为符号号位,也就是2的7次⽅减1,也就是127,取值范围为-128~127,为什么需要减1,这个问题就需要考虑临界值的问题了。
⽽考虑临界值问题⼜有需要讨论原码补码反码的知识,这些度不是我们讨论的重点,所以在这就⾃⾏百度。
给出⼀张范围表,给⼤家做参考。
不同整数类型的取值范围 根据⾃⼰所需去选取不同的类型名称, 例如: CREATE TABLE aaa( id INT(10) PRIMARY KEY, age INT(6) ); 这个例⼦中INT(10)、INT(6) 括号中的数字表⽰的是该数据类型指定的显⽰宽度,指定能够显⽰的数值中数字的个数。
MySQL数据类型详解及使用方法
MySQL数据类型详解及使用方法MySQL是一种广泛使用的关系型数据库管理系统,被广泛应用于各种规模的企业和个人项目中。
在MySQL中,数据类型是一项关键的概念,用于定义数据库表中的字段类型以及数据的存储方式。
本文将详细介绍MySQL中常用的数据类型及其使用方法,帮助读者更好地理解和运用MySQL。
一、字符型数据类型1. CHAR:CHAR数据类型用于存储固定长度的字符,最多可存储255个字符。
例如,可以使用CHAR(10)来存储一个固定长度为10个字符的字符串。
需要注意的是,如果实际存储的字符数少于指定的长度,MySQL会在末尾填充空格字符。
2. VARCHAR:VARCHAR数据类型用于存储可变长度的字符串,最多可存储65535个字符。
与CHAR不同,VARCHAR只会存储实际使用的字符数,不会占据固定的空间。
例如,可以使用VARCHAR(50)来存储最多长度为50的字符串。
3. TEXT:TEXT数据类型适用于存储大量文本数据,最多可存储65535个字符。
相比于VARCHAR,TEXT类型没有长度限制,适用于存储较长的文本数据,如文章内容或日志记录。
二、数值型数据类型1. INT:INT数据类型用于存储整数,范围为-2147483648到2147483647。
可以使用INT(11)来指定显示宽度,但实际存储的位数不受影响。
2. FLOAT:FLOAT数据类型用于存储单精度浮点数,适用于存储较小的浮点数。
可以使用FLOAT(p,d)来指定显示宽度和小数点位数,其中p表示总位数,d表示小数点后的位数。
3. DOUBLE:DOUBLE数据类型用于存储双精度浮点数,适用于存储较大的浮点数。
与FLOAT类似,可以使用DOUBLE(p,d)来指定显示宽度和小数点位数。
三、日期和时间型数据类型1. DATE:DATE数据类型用于存储日期,格式为YYYY-MM-DD。
例如,可以使用DATE来存储生日或注册日期等信息。
Mysql数据类型(字段)介绍
MySql数据库的列类型(字段类型)MySQL数据库的表是一个二维表,由一个或多个数据列构成。
每个数据列都有它的特定类型,该类型决定了MySQL如何看待该列数据,我们可以把整型数值存放到字符类型的列中,MySQL则会把它看成字符串来处理。
MySQL中的列类型有三种:数值类、字符串类和日期/时间类。
从大类来看列类型和数值类型一样,都是只有三种。
但每种列类型都还可细分。
下面对各种列类型进行详细介绍。
数值类的数据列类型数值型的列类型包括整型和浮点型两大类。
TINYINT:1字节非常小的正整数,带符号:-128~127,不带符号:0~255SMALLINT:2字节小整数,带符号:-32768~32767,不带符号:0~65535MEDIUMINT:3字节中等大小的整数,带符号:-8388608~8388607,不带符号:0~16777215INT:4字节标准整数,带符号:-2147483648~2147483647,不带符号:0~4294967295BIGINT:8字节大整数,带符号:-9223372036854775808~9233372036854775807,不带符号:0~18446744073709551615FLOAT:4字节单精度浮点数,最小非零值:+-1.175494351E-38,最大非零值:+-3.402823466E+38 DOUBLE:8字节双精度浮点数,最小非零值:+-2.2250738585072014E-308,最大非零值:+-1.7976931348623157E+308DECIMAL:M+2字节以字符串形式表示的浮点数,它的取值范围可变,由M和D的值决定。
整型数据列类型MySQL有五种整型数据列类型,即TINYINT,SMALLINT,MEDIUMINT,INT和BIGINT。
它们之间的区别是取值范围不同,存储空间也各不相同。
在整型数据列后加上UNSIGNED属性可以禁止负数,取值从0开始。
mysql数据库的number类型
mysql数据库的number类型全文共四篇示例,供读者参考第一篇示例:MySQL数据库的Number类型是一种非常常用的数据类型,它用来存储数值型数据,包括整数和小数。
在实际的数据库设计和开发中,我们经常会用到Number类型来存储各种数字数据,比如订单金额、产品价格、数量等等。
在本文中,我们将详细介绍MySQL数据库中的Number类型,包括其各种子类型和用法。
MySQL数据库中的Number类型主要包括两种子类型,即整数型和浮点型。
整数型包括TINYINT、SMALLINT、MEDIUMINT、INT和BIGINT,分别用来存储不同范围的整数数据。
浮点型包括FLOAT和DOUBLE,用来存储小数数据。
下面我们将分别介绍这些Number类型的特点和用法。
1. TINYINTTINYINT类型用来存储小范围的整数数据,取值范围为-128到127。
TINYINT类型占用1个字节的存储空间,适用于存储性别、状态等只有两个取值的数据。
6. FLOATFLOAT类型用来存储单精度浮点数,即小数数据。
FLOAT类型占用4个字节的存储空间,可以存储6-7位的有效数字,适用于存储科学计算、工程测量等领域的数据。
第二篇示例:MySQL数据库中的number类型主要用于存储数值型数据,包括整型和浮点型两种。
整型数据包括TINYINT、SMALLINT、MEDIUMINT、INT和BIGINT,而浮点型数据包括FLOAT和DOUBLE。
在数据库表的设计中,合理地选择number类型可以提高数据库的性能和数据存储效率。
让我们来了解一下MySQL数据库中number类型的具体描述和用法。
1. TINYINT:TINYINT类型用于存储非常小的整数数据,范围在-128到127之间。
它占用1个字节的存储空间,适用于存储布尔类型数据或者只需要记录小整数的场景。
6. FLOAT:FLOAT类型用于存储单精度浮点数数据,范围在-3.402823466E+38到-1.175494351E-38、0和1.175494351E-38到3.402823466E+38之间。
MySQL数据库常见的数据类型
MySQL数据库常见的数据类型MySQL提供的数据类型包括数值类型(整数类型和⼩数类型)、字符串类型、⽇期类型、复合类型(复合类型包括enum类型和set类型)以及⼆进制类型。
1,整数类型:整数类型的数,默认情况下既可以表⽰正整数⼜可以表⽰负整数(此时称为有符号数)。
如果只希望表⽰零和正整数,可以使⽤⽆符号关键字“unsigned”对整数类型进⾏修饰。
例如:score tinyint unsigned各个类别存储空间及取值范围。
2,⼩数类型decimal(length, precision)⽤于表⽰精度确定(⼩数点后数字的位数确定)的⼩数类型,length决定了该⼩数的最⼤位数,precision⽤于设置精度(⼩数点后数字的位数)。
例如: decimal (5,2)表⽰⼩数取值范围:999.99~999.99 decimal (5,0)表⽰: -99999~99999的整数。
3,字符串char()与varchar(): 例如对于简体中⽂字符集gbk的字符串⽽⾔,varchar(255)表⽰可以存储255个汉字,⽽每个汉字占⽤两个字节的存储空间。
假如这个字符串没有那么多汉字,例如仅仅包含⼀个‘中’字,那么varchar(255)仅仅占⽤1个字符(两个字节)的储存空间;⽽char(255)则必须占⽤255个字符长度的存储空间,哪怕⾥⾯只存储⼀个汉字。
4,⽇期类型。
date表⽰⽇期,默认格式为‘YYYY-MM-DD’; time表⽰时间,格式为‘HH:ii:ss’; year表⽰年份; datetime与timestamp是⽇期和时间的混合类型,格式为'YYYY-MM-DD HH:ii:ss'datetime与timestamp都是⽇期和时间的混合类型,区别在于:表⽰的取值范围不同,datetime的取值范围远远⼤于timestamp的取值范围。
将NULL插⼊timestamp字段后,该字段的值实际上是MySQL服务器当前的⽇期和时间。
php数据库,mysql字段类型,字段属性详解
本文由lchengm贡献 doc1。
MySQL 字段类型详解 MySQL 提 供 了 整 数 和 浮 点 数 的 数 值 类 型 。
可 根 据 所 要 表 示 的 值 的 范 围 选 择 相 应 的 类 型 。
对 于 整 数 类 型 , 如 果 指 定 了 AUTO_INCREMENT 属 性 , 则 列 必 须 为 PRIMARY KEY 或 UNIQUE 索 引 。
将 NULL 插 入 AUTO_INCREMENT 列 将 会 插 入 一 个 大 于 该 列 中 当 前 最 大 值 的 值 。
如 果 指 定 了 UNSIGNED 属 性 , 则 相 应 的 整 数 类 型 不 允 许 取 负 值 。
如 果 指 定 了 ZEROFILL 属 性 , 则 用 前 导 零 填 充 数 值 类 型 值 以 达 到 列 的 显 示 宽 度 。
1. TINYINT[(M)] 说明:非常小的整数 允 许 的 属 性 : AUTO _ I N C R E M E N T, UNSIGNED, ZEROFILL 取 值 范 围 : - 128 到 127( - 27 到 27- 1) 或 者 如 果 为 U N S I G N E D, 则 0 到 2 5 5 , ( 0 到 2 8-1) 缺 省 值 : 如 果 列 可 为 NULL; 则 为 NULL; 如 果 列 为 NOT NULL, 则 为 0 存储需求:1 字节 2. SMALLINT[(M)] 说明:小整数 允 许 的 属 性 : AUTO _ I N C R E M E N T, UNSIGNED, ZEROFILL 取 值 范 围 : - 32768 到 3 27 6 7( - 215 到 215- 1) 或 者 如 果 为 U N S I G N E D, 则 , 0 到 6 5 5 3 5( 0 到 216- 1) 缺 省 值 : 如 果 列 可 为 NULL; 则 为 NULL; 如 果 列 为 NOT NULL, 则 为 0 存储需求:2 字节 3. MEDIUMINT[(M)] 说明:中等大小的整数 允 许 的 属 性 : AUTO _ I N C R E M E N T, UNSIGNED, ZEROFILL 取 值 范 围 : -8388608 到 8 3 8 8 6 07( - 22 3 到 22 3- 1) 或 者 如 果 为 U N S I G N E , D, 则 0 到 16 7 7 2 15( 0 到 22 4- 1) 缺 省 值 : 如 果 列 可 为 NULL, 则 为 NULL; 如 果 列 为 NOT NULL, 则 为 0 存储需求:4 字节 4. INT[(M)] 说明:标准大小的整数 允 许 的 属 性 : AUTO _ I N C R E M E N T, UNSIGNED, ZEROFILL 取 值 范 围 : - 2147483648 到 2 14 7 4 8 3 6 4 7( - 231 到 2 3 1- 1) 或 者 如 果 为 U N , S I G N E D, 则 0 到 4 2 9 4 9 6 7 2 9 5( 0 到 2 3 2- 1) 缺 省 值 : 如 果 列 为 NULL, 则 为 NULL; 如 果 列 为 NOT FULL, 则 为 0 存储需求:4 字节 同 义 词 : I N T E G E R [(M)] 5. BIGINT[(M)] 说明:大整数 允 许 的 属 性 : AUTO _ I N C R E M E N T, UNSIGNED, ZEROFILL 取 值 范 围 : - 9223372036854775808 到 9 2 2 3 3 7 2 0 3 6 8 5 4 7 7 5 8 07( - 263 到 2 6 3- 1) 或 者 如 果 为 U N S I G N E D, 则 0 到 18 4 4 6 7 4 4 07 3 7 0 9 5 5 16 , 15( 0 到 26 4 -1) 缺 省 值 : 如 果 列 可 为 NULL, 则 为 NULL; 如 果 列 为 NOT NULL, 则 为 0 存储需求:8 字节 6. FLOAT [(M, D)] 说 明 : 小 浮 点 数 ; 单 精 度 ( 精 度 小 于 D O U B L E) 允许的属性:Z E R O F I L L 取 值 范 围 : 最 小 非 零 值 为 ±1.75494351E -38; 最 大 非 零 值 为 ±3 . 4 0 2 8 2 3 4 6 6 E + 3 8 缺 省 值 : 如 果 列 可 为 NULL, 则 为 NULL; 如 果 列 为 NOT NULL, 则 为 0 存储需求:4 字节 同 义 词 : MySQL3.23 版 以 前 , FLOAT(4) 为 具 有 缺 省 M 和 D 值 的 FLOAT 的 同 义 词 。
MySQL数据库的数据类型和字段属性详解
MySQL数据库的数据类型和字段属性详解引言MySQL是一种非常流行和常用的关系型数据库管理系统,广泛应用于各种网站和应用程序中。
在使用MySQL进行数据库设计和开发时,数据类型和字段属性的选择非常重要,它们直接影响着数据库的性能和数据的完整性。
本文将详细介绍MySQL数据库中常用的数据类型和字段属性,以便读者能够更好地理解和应用它们。
一、数值类型1. 整型(INT)整型是MySQL中最基本和常用的数据类型之一。
在MySQL中,整型包括int、tinyint、smallint、mediumint和bigint五种。
它们的区别在于存储范围和占用空间的大小。
例如,int类型的范围是-2147483648到2147483647,占用空间为4字节。
2. 浮点型(FLOAT和DOUBLE)浮点型用于存储小数,包括单精度浮点类型(FLOAT)和双精度浮点类型(DOUBLE)。
FLOAT类型占用4字节,DOUBLE类型占用8字节。
浮点型能够存储非常大和非常小的数字,但是在精度上有一定的限制。
3. 定点类型(DECIMAL)定点类型用于存储精确的小数,其精度和范围可以由用户自定义。
DECIMAL类型在数据库中的存储是以字符串形式存储的,它具有较高的精度和较小的存储空间。
二、字符串类型1. 字符型(CHAR和VARCHAR)字符型用于存储字符串,包括固定长度的字符类型(CHAR)和可变长度的字符类型(VARCHAR)。
CHAR类型在数据库中占用固定的空间,而VARCHAR 类型根据存储的内容变化而变化。
CHAR类型在存储短字符串时效率较高,而VARCHAR类型适用于存储可变长度的内容。
2. 文本型(TEXT)文本型用于存储较长的字符串,其分为四种类型:TINYTEXT、TEXT、MEDIUMTEXT和LONGTEXT。
它们分别用于存储不同长度的文本内容,MEDIUMTEXT类型可以存储最大长度为16MB的文本。
三、日期和时间类型1. 日期类型(DATE)日期类型用于存储日期,包括年、月、日。
MySQL中常见的数据类型及其用途
MySQL中常见的数据类型及其用途MySQL是一种常用的关系型数据库管理系统,被广泛应用于Web开发和其他领域。
在MySQL中,数据类型是数据表中各列的属性之一,它定义了数据的存储格式、占用空间和操作行为。
不同的数据类型适用于不同的数据存储需求和数据操作操作。
本文将介绍MySQL中常见的数据类型及其用途。
1. 整型数据类型整型数据类型用于存储整数值,常见的有以下几种:- TINYINT:存储范围为-128到127的整数。
通常用于存储布尔值,0表示假,1表示真。
- SMALLINT:存储范围为-32768到32767的整数。
适用于存储较小的整数值。
- MEDIUMINT:存储范围为-8388608到8388607的整数。
适用于存储中等大小的整数值。
- INT:存储范围为-2147483648到2147483647的整数。
适用于存储一般大小的整数值。
- BIGINT:存储范围为-9223372036854775808到9223372036854775807的整数。
适用于存储较大的整数值。
整型数据类型用于存储整数,经常用于记录索引、主键或表示计数值。
2. 浮点型数据类型浮点型数据类型用于存储浮点数值,即带有小数点的数值。
常见的有以下几种:- FLOAT:单精度浮点数,占用4字节。
通常用于存储较小范围的浮点数。
- DOUBLE:双精度浮点数,占用8字节。
适用于存储较大范围的浮点数。
浮点型数据类型用于存储需要保留小数位的数值,如货币金额、科学计数法表示的数值等。
3. 定点型数据类型定点型数据类型用于存储固定精度的数值,适用于需要精确计算的场景。
常见的有以下几种:- DECIMAL:用于存储固定精度的十进制数值。
可以指定精度和小数位数。
定点型数据类型适用于要求高精度计算的场景,如财务计算、精确测量等。
4. 字符串型数据类型字符串型数据类型用于存储文本数据,常见的有以下几种:- CHAR:固定长度字符串,最多可以存储255个字符。
MySQL数据类型(最大值和最小值)
MySQL数据类型(最⼤值和最⼩值)MySQL数据类型(最⼤值和最⼩值)1、整型MySQL数据类型含义(有符号)tinyint(m)1个字节范围(-128~127)smallint(m)2个字节范围(-32768~32767)mediumint(m)3个字节范围(-8388608~8388607)int(m)4个字节范围(-2147483648~2147483647)bigint(m)8个字节范围(+-9.22*10的18次⽅)取值范围如果加了unsigned,则最⼤值翻倍,如tinyint unsigned的取值范围为(0~255)。
int(m)⾥的m是表⽰SELECT查询结果集中的显⽰宽度,不知道这个m有什么⽤。
int 占10位,存不了⼿机号(11位)2、浮点型(float和double) 浮点型在数据库中存放的是近似值MySQL数据类型含义float(m,d)单精度浮点型 8位精度(4字节) m总个数,d⼩数位double(m,d)双精度浮点型 16位精度(8字节) m总个数,d⼩数位设⼀个字段定义为float(5,3),如果插⼊⼀个数123.45678,实际数据库⾥存的是123.457,但总个数还以实际为准,即6位。
3、定点数定点类型在数据库中存放的是精确值浮点型在数据库中存放的是近似值,⽽定点类型在数据库中存放的是精确值。
decimal(m,d) 参数m<65 是总个数,d<30且 d<m 是⼩数位。
4、字符串(char,varchar,_text)MySQL数据类型含义char(n)固定长度,最多255个字符varchar(n)可变长度,最多65535个字节tinytext可变长度,最多255个字符text可变长度,最多65535个字符mediumtext可变长度,最多2的24次⽅-1个字符longtext可变长度,最多2的32次⽅-1个字符。
mysql基本数据类型
mysql基本数据类型MySQL是一种关系型数据库管理系统,它支持多种数据类型。
MySQL的数据类型分为数值类型、日期和时间类型、字符串类型、二进制类型。
以下是MySQL基本数据类型(注意:各类型数据的存储要占用的字节数,不同的数据库系统、不同的编译选项这些大小限制和取值范围有所不同):1. 数值类型MySQL数值类型有整数类型和小数类型两种:1.1 整数类型- TINYINT:有符号范围为-128~127,无符号范围0~255。
占用1个字节。
- SMALLINT:有符号范围为-32768~32767,无符号范围0~65535。
占用2个字节。
- MEDIUMINT:有符号范围为-8388608~8388607,无符号范围0~16777215。
占用3个字节。
- INT:有符号范围为-2147483648~2147483647,无符号范围0~4294967295。
占用4个字节。
- BIGINT:有符号范围为-9223372036854775808~9223372036854775807,无符号范围0~18446744073709551615。
占用8个字节。
1.2 小数类型- FLOAT:单精度浮点数,占用4个字节。
- DOUBLE:双精度浮点数,占用8个字节。
- DECIMAL:高精度浮点数,依赖于实际存储的数字大小而变化。
2. 日期和时间类型MySQL日期和时间类型包括DATE、TIME、DATETIME、YEAR和TIMESTAMP:- DATE:日期,存储的范围为'1000-01-01'到'9999-12-31'。
占用3个字节。
- TIME:时间,存储的范围为 '-838:59:59'到 '838:59:59'。
占用3个字节。
- DATETIME:日期时间,存储范围为 '1000-01-01 00:00:00'到 '9999-12-31 23:59:59'。
MySQL的数据类型
MySQL的数据类型⽬录MySQL的数据类型数据库中的每个列都应该有适当的数据类型,⽤于限制或允许该列中存储的数据。
例如,列中存储的为数字,则相应的数据类型应该为数值类型。
如果使⽤错误的数据类型可能会严重影响应⽤程序的功能和性能,所以在设计表时,应该特别重视数据列所⽤的数据类型。
更改包含数据的列不是⼀件⼩事,这样做可能会导致数据丢失。
因此,在创建表时必须为每个列设置正确的数据类型和长度。
MySQL中定义数据字段的类型对你数据库的优化是⾮常重要的。
MySQL⽀持所有标准SQL数值数据类型。
MySQL⽀持多种类型,⼤致可以分为三类:数值⽇期/时间字符(串)类型。
数据类型分类1. 数值类型(整数类型和⼩数类型)整数类型:包括 TINYINT、SMALLINT、MEDIUMINT、INT、BIGINT。
⼩数类型:浮点数类型包括 FLOAT 和 DOUBLE。
定点数类型为 DECIMAL。
2. ⽇期/时间类型包括 YEAR、TIME、DATE、DATETIME 和 TIMESTAMP。
3. 字符类型(⽂本字符串和⼆进制字符串)字符串类型:包括 CHAR、VARCHAR、BINARY、VARBINARY、BLOB、TEXT、ENUM 和 SET 等。
⼆进制类型:包括 BIT、BINARY、VARBINARY、TINYBLOB、BLOB、MEDIUMBLOB 和 LONGBLOB。
数值类型MySQL⽀持所有标准SQL数值数据类型。
这些类型包括严格数值数据类型(INTEGER、SMALLINT、DECIMAL和NUMERIC),以及近似数值数据类型(FLOAT、REAL和DOUBLEPRECISION)。
关键字INT是INTEGER的同义词,关键字DEC是DECIMAL的同义词。
BIT数据类型保存位字段值,并且⽀持MyISAM、MEMORY、InnoDB和BDB表。
作为SQL标准的扩展,MySQL也⽀持整数类型TINYINT、MEDIUMINT和BIGINT。
mysql 列类型
MySQL 列类型概述MySQL支持多种列类型:数值类型、日期/时间类型和字符串(字符)类型。
几种列类型描述使用了下述惯例:M 表示最大显示宽度,最大有效显示宽度是255;D 适用于浮点和定点类型,并表示小数点后面的位数。
最大可能的值是30,但不应大于M-2。
方括号([])表示可选部分。
1、数值类型概述如果为一个数值列指定ZEROFILL,MySQL自动为该列添加UNSIGNED属性。
SERIAL是BIGINT UNSIGNED NOT NULL AUTO_INCREMENT UNIQUE的一个别名。
在整数列定义中,SERIAL DEFAULT VALUE是NOT NULL AUTO_INCREMENT UNIQUE的一个别名。
类型范围说明:类型字节最小值最大值TINYINT 1 带符号的 -128 127无符号0 255SMALLINT 2 带符号的 -32768 32767无符号0 65535MEDIUMINT 3 带符号的-8388608 8388607无符号0 16777215INT 4 带符号的-2147483648 2147483647无符号0 4294967295BIGINT 8 带符号的-92233720368547758089223372036854775807 无符号0 184467440737095516151.1、BITBIT[(M)]位字段类型。
M表示每个值的位数,范围为从1到64。
如果M被省略,默认为1。
1.2、INYINTINYINT[(M)] [UNSIGNED] [ZEROFILL]很小的整数。
带符号的范围是-128到127。
无符号的范围是0到255。
1.3、BOOLBOOL,BOOLEAN是TINYINT(1)的同义词。
zero值被视为假。
非zero值视为真。
在将来,将根据标准SQL引入完全布尔类型的处理。
1.4、SMALLINTSMALLINT[(M)] [UNSIGNED] [ZEROFILL]小的整数。
MySQL中的数据类型和字段属性详解
MySQL中的数据类型和字段属性详解引言MySQL是一种流行且广泛使用的关系型数据库管理系统。
在MySQL中,数据类型和字段属性是定义表结构和存储数据的关键概念。
了解不同的数据类型和字段属性对于设计和优化数据库架构至关重要。
本文将深入探讨MySQL中的数据类型和字段属性,帮助读者更好地理解和应用这些概念。
一、数据类型数据类型是指数据存储的格式和范围,MySQL提供了一系列的数据类型来满足不同的需求。
常见的数据类型包括整数型、浮点型、日期与时间型、字符串型等。
下面将详细介绍几种常用的数据类型。
1.1 整数型整数型是存储整数类型数据的一种数据类型。
在MySQL中,整数型可以分为有符号整数型和无符号整数型。
有符号整数型可表示负数、零和正数,而无符号整数型只能表示零和正数。
MySQL提供了多种整数型,如TINYINT、SMALLINT、INT、BIGINT等,它们的存储范围和占用空间不同,使用时需根据需求选择合适的类型。
1.2 浮点型浮点型是存储浮点数类型数据的一种数据类型。
MySQL提供了两种浮点型:FLOAT和DOUBLE。
FLOAT类型占用4个字节,DOUBLE类型占用8个字节。
浮点型适用于存储小数,可以表示较大或较小的数值范围。
1.3 日期与时间型日期与时间型用于存储日期和时间信息。
MySQL提供了多种日期与时间型,如DATE、TIME、DATETIME、TIMESTAMP等。
这些类型可用于存储不同精确度和范围的日期与时间数据。
例如,DATE类型只存储年、月、日信息,而DATETIME类型存储年、月、日、时、分、秒信息。
1.4 字符串型字符串型是存储字符类型数据的一种数据类型。
MySQL中的字符串型包括固定长度字符串和可变长度字符串。
其中,CHAR类型为固定长度字符串,存储时会按照指定长度进行填充。
而VARCHAR类型为可变长度字符串,存储时会根据实际内容的长度进行存储,节省存储空间。
在选择字符串型时,需根据实际需要考虑存储空间和查询性能的平衡。
mysql float详解
mysql float详解MySQL是一种流行的关系型数据库管理系统,而float是MySQL 中的一种数值数据类型。
本文将详细介绍MySQL中的float类型及其相关内容。
在MySQL中,float表示一个单精度浮点数,它可以存储大约7位有效数字,并且占用4个字节的存储空间。
float类型的数据范围是从-3.402823466E+38到-1.175494351E-38、0和从1.175494351E-38到3.402823466E+38。
使用float类型存储小数时需要注意,由于浮点数的特殊性,会存在一定的精度问题。
例如,当使用float类型存储小数时,可能会出现精度丢失的情况。
因此,在需要精确计算小数的场景下,建议使用decimal类型而不是float类型。
在MySQL中,可以通过以下方式定义float类型的列:CREATE TABLE table_name (column_name FLOAT(size, d));其中,size表示数值的总位数,d表示小数的位数。
如果不指定size和d,则默认为FLOAT(10,2)。
例如,可以使用以下语句创建一个名为table_name的表,其中包含一个名为column_name的float类型列:CREATE TABLE table_name (column_name FLOAT(10,2));在实际使用中,float类型可以存储各种数值,例如存储货币金额、温度、体重等。
由于float类型的存储空间相对较小,因此适合存储范围较大但精度要求不高的数值。
在查询和操作float类型的数据时,可以使用各种MySQL内置的数学函数和运算符。
例如,可以使用ROUND函数对float类型的数据进行四舍五入。
另外,可以使用加号、减号、乘号、除号等运算符对float类型的数据进行基本的数学运算。
除了基本的数学运算外,MySQL还提供了一些特殊的函数,例如CEILING、FLOOR、ABS等,可以对float类型的数据进行上取整、下取整、绝对值等操作。
mysql数据类型
mysql 数据类型2009年07月18日星期六15:57在计算机中数据有两种特征:类型和长度。
所谓数据类型就是以数据的表现方式和存储方式来划分的数据的种类。
在SQL Server 中每个变量、参数、表达式等都有数据类型。
系统提供的数据类型分为几大类,。
其中,BIGINT、SQL_V ARIANT 和TABLE 是SQL Server 2000 中新增加的3 种数据类型。
下面分类讲述各种数据类型。
4.3.1 整数数据类型整数数据类型是最常用的数据类型之一。
1、INT (INTEGER)INT (或INTEGER)数据类型存储从-2的31次方(-2 ,147 ,483 ,648)到2的31次方-1 (2 ,147 ,483,647)之间的所有正负整数。
每个INT 类型的数据按4 个字节存储,其中1 位表示整数值的正负号,其它31 位表示整数值的长度和大小。
2、SMALLINTSMALLINT 数据类型存储从-2的15次方(-32,768)到2的15次方-1(32 ,767 )之间的所有正负整数。
每个SMALLINT 类型的数据占用2 个字节的存储空间,其中1 位表示整数值的正负号,其它15 位表示整数值的长度和大小。
3、TINYINTTINYINT数据类型存储从0 到255 之间的所有正整数。
每个TINYINT类型的数据占用1 个字节的存储空间。
4、BIGINTBIGINT 数据类型存储从-2^63 (-9 ,223,372,036,854,775,807)到2^63-1(9,223,372,036 ,854 ,775,807)之间的所有正负整数。
每个BIGINT 类型的数据占用8个字节的存储空间。
4.3.2 浮点数据类型浮点数据类型用于存储十进制小数。
浮点数值的数据在SQL Server 中采用上舍入(Round up 或称为只入不舍)方式进行存储。
所谓上舍入是指,当(且仅当)要舍入的数是一个非零数时,对其保留数字部分的最低有效位上的数值加1 ,并进行必要的进位。
MySQL数据库知识点整理
MySQL数据库知识点整理1. Mysql 的存储引擎,myisam和innodb的区别?数据表类型有哪些?答:主要区别: 1)InnoDB⽀持事务,MyISAM不⽀持,对于InnoDB每⼀条SQL语⾔都默认封装成事务,⾃动提交,这样会影响速度,所以最好把多条SQL语⾔放在begin和commit之间,组成⼀个事务; 2)InnoDB⽀持外键,⽽MyISAM不⽀持。
对⼀个包含外键的InnoDB表转为MYISAM会失败; 3) InnoDB是聚集索引,数据⽂件是和索引绑在⼀起的,必须要有主键,通过主键索引效率很⾼。
但是辅助索引需要两次查询,先查询到主键,然后再通过主键查询到数据。
因此,主键不应该过⼤,因为主键太⼤,其他索引也都会很⼤。
⽽MyISAM是⾮聚集索引,数据⽂件是分离的,索引保存的是数据⽂件的指针。
主键索引和辅助索引是独⽴的。
4) InnoDB不保存表的具体⾏数,执⾏select count(*) from table时需要全表扫描。
⽽MyISAM⽤⼀个变量保存了整个表的⾏数,执⾏上述语句时只需要读出该变量即可,速度很快; 5)Innodb不⽀持全⽂索引,⽽MyISAM⽀持全⽂索引,查询效率上MyISAM要⾼;概括总结:MyISAM 是⾮事务的存储引擎,适合⽤于频繁查询的应⽤。
表锁,不会出现死锁,适合⼩数据,⼩并发。
innodb是⽀持事务的存储引擎,合于插⼊和更新操作⽐较多的应⽤,设计合理的话是⾏锁(最⼤区别就在锁的级别上),适合⼤数据,⼤并发。
数据表类型有:MyISAM、InnoDB、HEAP、BOB,ARCHIVE,CSV等。
MyISAM:成熟、稳定、易于管理,快速读取。
⼀些功能不⽀持(事务等),表级锁。
InnoDB:⽀持事务、外键等特性、数据⾏锁定。
空间占⽤⼤,不⽀持全⽂索引等。
应⽤场景: 1).MyISAM管理⾮事务表。
它提供⾼速存储和检索,以及全⽂搜索能⼒。
如果应⽤中需要执⾏⼤量的SELECT查询,那么MyISAM是更好的选择。
MySQL数据类型及字段设置指南
MySQL数据类型及字段设置指南MySQL是一个流行的关系型数据库管理系统,广泛用于开发各种类型的应用程序。
在MySQL中,数据类型和字段设置是非常重要的,决定了数据库的性能和数据的完整性。
本文将为您介绍MySQL中常见的数据类型及字段设置指南,帮助您优化数据库设计和管理。
一、数据类型选择1. 整数类型在MySQL中,我们可以选择多种整数类型来存储不同范围的整数数据。
常见的整数类型有:TINYINT、SMALLINT、INT、BIGINT。
选择适当的整数类型可以有效地节约存储空间和提高查询效率。
例如,如果你需要存储0到9之间的整数,可以选择TINYINT类型,因为TINYINT只占用1个字节的存储空间,远远小于INT类型占用的4个字节。
2. 浮点数类型在MySQL中,我们可以使用FLOAT和DOUBLE来存储浮点数数据。
FLOAT 占用4个字节,DOUBLE占用8个字节。
FLOAT适用于小范围的浮点数数据,而DOUBLE适用于大范围的浮点数数据。
需要注意的是,浮点数类型存在精度问题。
如果对数据的精度要求较高,可以考虑使用DECIMAL类型,它可以指定精度和小数位数。
3. 字符串类型在MySQL中,我们可以使用多种字符串类型存储字符数据。
常见的字符串类型有:CHAR、VARCHAR、TEXT。
CHAR类型适用于固定长度的字符数据。
例如,如果你要存储一个长度为10的用户名,可以选择CHAR(10)类型,这样可以提高查询效率。
VARCHAR类型适用于可变长度的字符数据。
例如,如果你要存储不定长度的文章内容,可以选择VARCHAR类型。
需要注意的是,CHAR和VARCHAR类型的区别在于CHAR类型会为每个记录分配固定长度的存储空间,而VARCHAR类型只为实际存储的数据分配足够的空间。
4. 日期和时间类型在MySQL中,我们可以使用DATE、TIME、DATETIME等类型存储日期和时间数据。
DATE类型用于存储日期数据。
MySQL日期数据类型、时间类型使用总结
MySQL⽇期数据类型、时间类型使⽤总结1、MySQL的五种⽇期和时间类型MySQl中有多种表⽰⽇期和时间的数据类型。
其中YEAR表⽰年份,DATE表⽰⽇期,TIME表⽰时间,DATETIME和TIMESTAMP表⽰⽇期和实践。
它们的对⽐如下:TEAR ,字节数为1,取值范围为“1901——2155”DATE,字节数为4,取值范围为“1000-01-01——9999-12-31”TIME,字节数为3,取值范围为“-838:59:59——838:59:59”DATETIME,字节数为8,取值范围为“1000-01-01 00:00:00——9999-12-31 23:59:59”TIMESTAMP,字节数为4,取值范围为“19700101080001——20380119111407”当插⼊值超出有效取值范围时,系统会报错,并将零值插⼊到数据库中。
2、YEAR类型给YEAR类型复制可以有三种⽅法。
第⼀种是直接插⼊4位字符串或者4位数字。
第⼆种是插⼊2位字符串,这种情况下如果插⼊‘00’~‘69’,则相当于插⼊2000~2069;如果插⼊‘70’~‘99’,则相当于插⼊1970~1999。
第⼆种情况下插⼊的如果是‘0’,则与插⼊‘00’效果相同,都是表⽰2000年。
第三种是插⼊2位数字,它与第⼆种(插⼊两位字符串)不同之处仅在于:如果插⼊的是⼀位数字0,则表⽰的是0000,⽽不是2000年。
所以在给YEAR类型赋值时,⼀定要分清0和‘0’,虽然两者相差个引号,但实际效果确实相差了2000年。
3、TIME类型TIME类型表⽰为“时:分:秒”,尽管⼩时范围⼀般是0~23,但是为了表⽰某些特殊时间间隔,MySQL将TIME的⼩时范围扩发了,⽽且⽀持负值。
对TIME类型赋值,标准格式是‘HH:MM:SS’,但不⼀定⾮要是这种格式。
如果插⼊的是‘D HH:MM:SS’格式,则类似插⼊了‘(D*24+HH):MM:SS’。
MySQL中的数据类型和数据长度选择指南
MySQL中的数据类型和数据长度选择指南引言在数据库设计和开发中,正确选择合适的数据类型和数据长度对于数据的存储和查询效率具有重要的影响。
MySQL作为一种流行的关系型数据库管理系统,提供了丰富的数据类型供开发者选择。
本文将介绍MySQL中常见的数据类型,并探讨如何选择恰当的数据长度来优化数据库性能。
一、整数类型1. TINYINTTINYINT类型用于存储小整数,范围为-128到127。
当存储不需要较大范围的整数时,选择TINYINT类型可以节省存储空间。
2. SMALLINTSMALLINT类型适用于存储较大范围的整数,范围为-32768到32767。
当整数范围在TINYINT和INT之间时,可以选择SMALLINT类型。
3. INTINT类型是MySQL中最常用的整数类型,范围为-2147483648到2147483647。
除非特殊需求,一般情况下选用INT类型即可满足需求。
4. BIGINT当需要存储超过INT类型范围的整数时,可以选择BIGINT类型。
BIGINT类型的范围为-9223372036854775808到9223372036854775807。
需要注意的是,由于BIGINT类型占用更多的存储空间,因此在选择时需要权衡存储空间和性能。
二、浮点数类型1. FLOATFLOAT类型适用于存储单精度浮点数,可以存储小数点后6到7位有效数字。
当需要存储较大范围的小数时,可以选择FLOAT类型。
2. DOUBLEDOUBLE类型是MySQL中默认的浮点数类型,用于存储双精度浮点数。
DOUBLE类型可以存储小数点后15到16位有效数字。
在需要更高精度的计算场景中,可以选择DOUBLE类型。
三、字符串类型1. CHARCHAR类型用于存储固定长度的字符串,长度取决于指定的字符数。
选择CHAR类型时,需要注意该字段的实际使用情况,避免浪费存储空间。
2. VARCHARVARCHAR类型适用于存储可变长度的字符串,长度可以在1到65535之间指定。
MySQL数据类型DECIMAL用法详解
MySQL数据类型DECIMAL⽤法详解MySQL DECIMAL数据类型⽤于在数据库中存储精确的数值。
我们经常将DECIMAL数据类型⽤于保留准确精确度的列,例如会计系统中的货币数据。
要定义数据类型为DECIMAL的列,请使⽤以下语法:column_name DECIMAL(P,D);在上⾯的语法中:P是表⽰有效数字数的精度。
P范围为1〜65。
D是表⽰⼩数点后的位数。
D的范围是0~30。
MySQL要求D⼩于或等于(<=)P。
DECIMAL(P,D)表⽰列可以存储D位⼩数的P位数。
⼗进制列的实际范围取决于精度和刻度。
与INT数据类型⼀样,DECIMAL类型也具有UNSIGNED和ZEROFILL属性。
如果使⽤UNSIGNED属性,则DECIMAL UNSIGNED的列将不接受负值。
如果使⽤ZEROFILL,MySQL将把显⽰值填充到0以显⽰由列定义指定的宽度。
另外,如果我们对DECIMAL列使⽤ZEROFILL,MySQL将⾃动将UNSIGNED属性添加到列。
以下⽰例使⽤DECIMAL数据类型定义的⼀个叫作amount的列。
amount DECIMAL(6,2);在此⽰例中,amount列最多可以存储6位数字,⼩数位数为2位; 因此,amount列的范围是从-9999.99到9999.99。
MySQL允许使⽤以下语法:column_name DECIMAL(P);这相当于:column_name DECIMAL(P,0);在这种情况下,列不包含⼩数部分或⼩数点。
此外,我们甚⾄可以使⽤以下语法。
column_name DECIMAL;在这种情况下,P的默认值为10。
MySQL DECIMAL存储MySQL分别为整数和⼩数部分分配存储空间。
MySQL使⽤⼆进制格式存储DECIMAL值。
它将9位数字包装成4个字节。
对于每个部分,需要4个字节来存储9位数的每个倍数。
剩余数字所需的存储如下表所⽰:剩余数字位001–213–425–637-94例如,DECIMAL(19,9)对于⼩数部分具有9位数字,对于整数部分具有19位=10位数字,⼩数部分需要4个字节。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
MySQL数据类型和常用字段属性总结●日期和时间数据类型
●数值数据类型
整型
上面定义的都是有符号的,当然了,也可以加上unsigned关键字,定义成无符号的类型,那么对应的取值范围就要翻翻了,比如:
tinyint unsigned的取值范围为0~255。
●浮点型
我在MySQL中建立了一个表,有一列为float(5, 3);做了以下试验:
1.插入123.45678,最后查询得到的结果为99.999;
2.插入12
3.456,最后查询结果为99.999;
3.插入12.34567,最后查询结果为12.346;
所以,在使用浮点型的时候,还是要注意陷阱的,要以插入数据库中的实际结果为准。
●字符串数据类型
1.char(n)和varchar(n)中括号中n代表字符的个数,并不代表字节个数,所以当使用了中文的时候(UTF8)意味着可以插入m个中文,但是实际会占用m*3个字节。
2.同时char和varchar最大的区别就在于char不管实际value都会占用n个字符的空间,而varchar只会占用实际字符应该占用的空间+1,并且实际空间+1<=n。
3.超过char和varchar的n设置后,字符串会被截断。
4.char的上限为255字节,varchar的上限65535字节,text的上限为65535。
5.char在存储的时候会截断尾部的空格,varchar和text不会。
6.varchar会使用1-3个字节来存储长度,text不会。
1.enum(“member1″, “member2″, … “member65535″)
enum数据类型就是定义了一种枚举,最多包含65535个不同的成员。
当定义了一个enum的列时,该列的值限制为列定义中声明的值。
如果列声明包含NULL属性,则NULL将被认为是一个有效值,并且是默认值。
如果声明了NOT NULL,则列表的第一个成员是默认值。
2.set(“member”, “member2″, … “member64″)
set数据类型为指定一组预定义值中的零个或多个值提供了一种方法,这组值最多包括64个成员。
值的选择限制为列定义中声明的值。
数据类型属性
上面大概总结了MySQL中的数据类型,当然了,上面的总结肯定是不全面的,如果要非常全面的总结这些内容,好几篇文章都不够的。
下面就再来总结一些常用的属性。
1.auto_increment
auto_increment能为新插入的行赋一个唯一的整数标识符。
为列赋此属性将为每个新插入的行赋值为上一次插入的ID+1。
MySQL要求将auto_increment属性用于作为主键的列。
此外,每个表只允许有一个auto_i ncrement列。
例如:
代码如下:
id smallint not null auto_increment primary key
2.binary
binary属性只用于char和varchar值。
当为列指定了该属性时,将以区分大小写的方式排序。
与之相反,忽略binary属性时,将使用不区分大小写的方式排序。
例如:
代码如下:
hostname char(25) binary not null
3.default
default属性确保在没有任何值可用的情况下,赋予某个常量值,这个值必须是常量,因为MySQL不允许插入函数或表达式值。
此外,此属性无法用于BLOB或TEXT列。
如果已经为此列指定了NULL属性,没有指定默认值时默认值将为NULL,否则默认值将依赖于字段的数据类型。
例如:
代码如下:
subscribed enum('0', '1') not null default '0'
4.index
如果所有其他因素都相同,要加速数据库查询,使用索引通常是最重要的一个步骤。
索引一个列会为该列创建一个有序的键数组,每个键指向其相应的表行。
以后针对输入条件可以搜索这个有序的键数组,与搜索整个未索引的表相比,这将在性能方面得到极大的提升。
代码如下:
create table employees
(
id varchar(9) not null,
firstname varchar(15) not null,
lastname varchar(25) not null,
email varchar(45) not null,
phone varchar(10) not null,
index lastname(lastname),
primary key(id)
);
我们也可以利用MySQL的create index命令在创建表之后增加索引:
复制代码代码如下:
create index lastname on employees (lastname(7));
这一次只索引了名字的前7个字符,因为可能不需要其它字母来区分不同的名字。
因为使用较小的索引时性能更好,所以应当在实践中尽量使用小的索引。
5.not null
如果将一个列定义为not null,将不允许向该列插入null值。
建议在重要情况下始终使用not null属性,因为它提供了一个基本验证,确保已经向查询传递了所有必要的值。
6.null
为列指定null属性时,该列可以保持为空,而不论行中其它列是否已经被填充。
记住,nu ll精确的说法是“无”,而不是空字符串或0。
7.primary key
primary key属性用于确保指定行的唯一性。
指定为主键的列中,值不能重复,也不能为空。
为指定为主键的列赋予auto_increment属性是很常见的,因为此列不必与行数据有任何关系,而只是作为一个唯一标识符。
主键又分为以下两种:
(1)单字段主键
如果输入到数据库中的每行都已经有不可修改的唯一标识符,一般会使用单字段主键。
注意,此主键一旦设置就不能再修改。
(2)多字段主键
如果记录中任何一个字段都不可能保证唯一性,就可以使用多字段主键。
这时,多个字段联合起来确保唯一性。
如果出现这种情况,指定一个auto_increment整数作为主键是更好的办法。
8.unique
被赋予unique属性的列将确保所有值都有不同的值,只是null值可以重复。
一般会指定一个列为unique,以确保该列的所有值都不同。
例如:
复制代码代码如下:
email varchar(45) unique
9.zerofill
zerofill属性可用于任何数值类型,用0填充所有剩余字段空间。
例如,无符号int的默认宽度是10;因此,当“零填充”的int值为4时,将表示它为0000000004。
例如:
复制代码代码如下:
orderid int unsigned zerofill not null。