[转]MySQL 字段类型参考

本文详细介绍了MySQL中的各种数据类型,包括数字类型、日期和时间类型、串类型等,并提供了每种类型的存储需求。

转自:http://www.cnblogs.com/Alacky/articles/937826.html

字段类型:
TINYINT[(M)] [UNSIGNED] [ZEROFILL] 
一个很小的整数。有符号的范围是-128到127,无符号的范围是0到255。

SMALLINT[(M)] [UNSIGNED] [ZEROFILL] 
一个小整数。有符号的范围是-32768到32767,无符号的范围是0到65535。

MEDIUMINT[(M)] [UNSIGNED] [ZEROFILL] 
一个中等大小整数。有符号的范围是-8388608到8388607,无符号的范围是0到16777215。

INT[(M)] [UNSIGNED] [ZEROFILL] 
一个正常大小整数。有符号的范围是-2147483648到2147483647,无符号的范围是0到4294967295。

INTEGER[(M)] [UNSIGNED] [ZEROFILL] 
这是INT的一个同义词。

BIGINT[(M)] [UNSIGNED] [ZEROFILL] 
一个大整数。有符号的范围是-9223372036854775808到9223372036854775807,无符号的范围是0到18446744073709551615。

FLOAT[(M,D)] [ZEROFILL] 
一个小(单精密)浮点数字。不能无符号。允许的值是-3.402823466E+38到-1.175494351E-38,0 和 1.175494351E-38到3.402823466E+38。M是显示宽度而D是小数的位数。没有参数的FLOAT或有<24 的一个 参数表示一个单精密浮点数字。

DOUBLE[(M,D)] [ZEROFILL] 
一个正常大小(双精密)浮点数字。不能无符号。允许的值是-1.7976931348623157E+308到-2.2250738585072014E-308、 
0和2.2250738585072014E-308到1.7976931348623157E+308。

DOUBLE PRECISION[(M,D)] [ZEROFILL] 
  
REAL[(M,D)] [ZEROFILL] 
这些是DOUBLE同义词。

DECIMAL[(M[,D])] [ZEROFILL] 
一个未压缩(unpack)的浮点数字。不能无符号。行为如同一个CHAR列:“未压缩”意味着数字作为一个字符串被存储,值的每一位使用一个字符。

NUMERIC(M,D) [ZEROFILL] 
这是DECIMAL的一个同义词。

DATE 
一个日期。支持的范围是'1000-01-01'到'9999-12-31'。MySQL以'YYYY-MM-DD'格式来显示DATE值,但是允许你使用字符串或数字把值赋给DATE列。

DATETIME 
一个日期和时间组合。支持的范围是'1000-01-01 00:00:00'到'9999-12-31 23:59:59'。MySQL以'YYYY-MM-DD HH:MM:SS'格式来显示DATETIME值,但是允许你使用字符串或数字把值赋给DATETIME的列。

TIMESTAMP[(M)] 
一个时间戳记。范围是'1970-01-01 00:00:00'到2037年的某时。MySQL以YYYYMMDDHHMMSS、 YYMMDDHHMMSS、YYYYMMDD或YYMMDD格式来显示TIMESTAMP值,取决于是否M是14(或省略)、12、8或6,但是允许你使用字符串或数字把值赋给TIMESTAMP列。一个TIMESTAMP列对于记录一个INSERT或UPDATE操作的日期和时间是有用的,因为如果你不自己给它赋值,它自动地被设置为最近操作的日期和时间。你以可以通过赋给它一个NULL值设置它为当前的日期和时间。

TIME 
一个时间。范围是'-838:59:59'到'838:59:59'。MySQL以'HH:MM:SS'格式来显示TIME值,但是允许你使用字符串或数字把值赋给TIME列。

YEAR[(2|4)] 
一个2或4位数字格式的年(缺省是4位)。允许的值是1901到2155,和0000(4位年格式),如果你使用2位,1970-2069( 70-69)。MySQL以YYYY格式来显示YEAR值,但是允许你把使用字符串或数字值赋给YEAR列。(YEAR类型在MySQL3.22中是新类型。)

CHAR(M) [BINARY] 
一个定长字符串,当存储时,总是是用空格填满右边到指定的长度。M的范围是1 ~ 255个字符。当值被检索时,空格尾部被删除。CHAR值根据缺省字符集以大小写不区分的方式排序和比较,除非给出BINARY关键词。NATIONAL CHAR(短形式NCHAR)是ANSI SQL的方式来定义CHAR列应该使用缺省字符集。这是MySQL的缺省。CHAR是CHARACTER的一个缩写。

[NATIONAL] VARCHAR(M) [BINARY] 
一个变长字符串。注意:当值被存储时,尾部的空格被删除(这不同于ANSI SQL规范)。M的范围是1 ~ 255个字符。 VARCHAR值根据缺省字符集以大小写不区分的方式排序和比较,除非给出BINARY关键词值。见7.7.1 隐式列指定变化。 VARCHAR是CHARACTER VARYING一个缩写。

TINYBLOB 
  
TINYTEXT 
一个BLOB或TEXT列,最大长度为255(2^8-1)个字符

BLOB 
  
TEXT 
一个BLOB或TEXT列,最大长度为65535(2^16-1)个字符

MEDIUMBLOB 
  
MEDIUMTEXT 
一个BLOB或TEXT列,最大长度为16777215(2^24-1)个字符

LONGBLOB 
  
LONGTEXT 
一个BLOB或TEXT列,最大长度为4294967295(2^32-1)个字符

ENUM('value1','value2',...) 
枚举。一个仅有一个值的字符串对象,这个值式选自与值列表'value1'、'value2', ...,或NULL。一个ENUM最多能有65535不同的值。

SET('value1','value2',...) 
一个集合。能有零个或多个值的一个字符串对象,其中每一个必须从值列表'value1', 'value2', ...选出。一个SET最多能有64个成员。 



 数字类型

列类型需要的存储量
TINYINT1 字节
SMALLINT2 个字节
MEDIUMINT3 个字节
INT4 个字节
INTEGER4 个字节
BIGINT8 个字节
FLOAT(X)4 如果 X < = 24 或 8 如果 25 < = X < = 53
FLOAT4 个字节
DOUBLE8 个字节
DOUBLE PRECISION8 个字节
REAL8 个字节
DECIMAL(M,D)M字节(D+2 , 如果M < D)
NUMERIC(M,D)M字节(D+2 , 如果M < D)

 日期和时间类型

列类型需要的存储量
DATE3 个字节
DATETIME8 个字节
TIMESTAMP4 个字节
TIME3 个字节
YEAR1 字节

 串类型

列类型需要的存储量
CHAR(M)M字节,1 <= M <= 255
VARCHAR(M)L+1 字节, 在此L <= M1 <= M <= 255
TINYBLOBTINYTEXTL+1 字节, 在此L< 2 ^ 8
BLOBTEXTL+2 字节, 在此L< 2 ^ 16
MEDIUMBLOBMEDIUMTEXTL+3 字节, 在此L< 2 ^ 24
LONGBLOBLONGTEXTL+4 字节, 在此L< 2 ^ 32
ENUM('value1','value2',...)1 或 2 个字节, 取决于枚举值的数目(最大值65535)
SET('value1','value2',...)1,2,3,4或8个字节, 取决于集合成员的数量(最多64个成员)

<think>我们正在处理一个关于MySQL数据库的问题:如何为decimal字段类型设置或修改默认值。根据用户的问题,我们需要参考提供的引用内容。引用[2]中提到了如何为JSON类型设置默认值,使用DEFAULT关键字。引用[3]提到了decimal字段类型,但没有直接说明如何设置默认值。引用[4]中展示了如何获取字段的默认值等信息,但没有直接说明如何设置。但是,我们知道在MySQL中,设置或修改字段的默认值通常使用ALTERTABLE语句。对于decimal类型,设置默认值的方法与其他数值类型类似。具体步骤:1.如果是在创建表时设置默认值,可以在定义字段时使用DEFAULT关键字。2.如果是在已存在的表中修改字段的默认值,可以使用ALTERTABLE语句修改字段的默认值。根据引用[2]中的示例,设置默认值使用DEFAULT后跟一个值。对于decimal类型,我们需要指定一个十进制数值作为默认值。示例:创建表时设置:CREATETABLEexample(idINTPRIMARYKEY,amountDECIMAL(10,2)DEFAULT0.00);修改现有表的字段默认值:ALTERTABLEexampleALTERCOLUMNamountSETDEFAULT0.00;或者(在MySQL中也可以使用MODIFYCOLUMN):ALTERTABLEexampleMODIFYCOLUMNamountDECIMAL(10,2)DEFAULT0.00;注意:修改字段的默认值不会影响已有的数据,只会影响后续插入的数据。另外,根据引用[3]中关于decimal的说明,decimal(M,D)中的M是总位数,D是小数位数。在设置默认值时,需要确保默认值符合定义的范围。因此,回答用户的问题:在MySQL中,可以通过以下两种方式为decimal字段设置或修改默认值:1.在创建表时,在字段定义中使用DEFAULT关键字指定默认值。2.在已有表中,使用ALTERTABLE语句,结合ALTERCOLUMN...SETDEFAULT或MODIFYCOLUMN来设置默认值。下面给出具体示例。</think>### 如何在 MySQL 中为 DECIMAL 字段设置或修改默认值 在 MySQL 中为 `DECIMAL` 字段设置默认值需通过以下两种方式实现: #### 1. 创建表时设置默认值(推荐) 在 `CREATE TABLE` 语句中使用 `DEFAULT` 关键字: ```sql CREATE TABLE 表名 ( 字段名 DECIMAL(总位数, 小数位数) DEFAULT 默认值 ); ``` **示例**: 创建商品表,为价格字段设置默认值 0.00: ```sql CREATE TABLE products ( id INT AUTO_INCREMENT PRIMARY KEY, price DECIMAL(10, 2) DEFAULT 0.00 -- 总位数10,小数位2,默认值0.00 ); ``` #### 2. 修改已有表的默认值 使用 `ALTER TABLE` 修改字段定义: ```sql ALTER TABLE 表名 MODIFY COLUMN 字段名 DECIMAL(总位数, 小数位数) DEFAULT 新默认值; ``` **示例**: 将订单表的金额字段默认值改为 100.50: ```sql ALTER TABLE orders MODIFY COLUMN amount DECIMAL(12, 2) DEFAULT 100.50; ``` #### ⚠️ 注意事项: 1. **默认值格式** 必须使用数值格式(如 `99.99`),禁止字符串格式(如 `'99.99'`),否则报错[^3]。 2. **范围匹配** 默认值需符合字段定义的范围。例如 `DECIMAL(5,2)` 的默认值不能超过 `999.99`[^4]。 3. **删除默认值** 将默认值设为 `NULL`(需确保字段允许为空): ```sql ALTER TABLE 表名 ALTER COLUMN 字段名 DROP DEFAULT; ``` 4. **默认值约束** 修改默认值不会影响已有数据,仅作用于新插入的记录[^2]。 --- ### 相关问题 1. `DECIMAL(10,2)` 和 `FLOAT` 类型在存储金额时有何区别? 2. 如何为 MySQL 的 JSON 类型字段设置默认值(如 `{"stock":0}`)[^2]? 3. 修改字段默认值时,如何避免影响现有数据的完整性? 4. 如何查询 MySQL 表结构中字段的默认值定义(类似 SQL Server 的 `information_schema`)[^4]? [^1]: ENUM 类型因为只允许在集合中取得一个值,有点类似于单选项。在处理相互排拆的数据时容易让人理解,比如人类的性别。 [^2]: 在 MySQL 中,可以使用 JSON 类型,并使用 DEFAULT 关键字来设置默认值。 [^3]: 数据库存储负值,如果某列设置为zerofill,那它自动就unsigned。这个值要配合int,tinyint,smallint,midiumint等字段的宽度指示器来用。 [^4]: SQL Server 获取数据表结构字段名,数据类型,默认值,长度,为空,说明。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值