`
liudaoru
  • 浏览: 1576285 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

MySQL int(X) 中 X 的含义

阅读更多

From: http://www.amxku.net/MySQL-int/

 

这个可选的宽度规格说明是用于在数值显示时,对某些值的宽度短于该列宽度的值进行左填补显示的,而不是为了限制在该列中存储值的宽度,也 不是为了限制那些超过该列指定宽度的值的可被显示的数字位数。注意,如果在一个整型列中存储一个超过显示宽度的更大值时,当 mysql 为某些复杂的联结(join)生成临时表时,你可能会遇到问题,因为在这种情况下,mysql 信任地认为所有的值均适合原始的列宽度。

而int本身就是4个字节 bigint是8个字节 所以说int(X)的含义就是 int决定数据存储的字节 X表示期望数据的列宽度

在SQL语句中int代表你要创建字段的类型,int代表整型,11代表字段的长度。

这个代表显示宽度
整数列的显示宽度与mysql需要用多少个字符来显示该列数值,与该整数需要的存储空间的大小都没有关系,比如,不管设定了显示宽度是多少个字符,bigint都要占用8个字节。

http://www.ccvita.com/index.php/175.html

分享到:
评论
1 楼 liudaoru 2008-11-03  
基础知识:MySQL数据类型及列类型
From: http://tech.itzero.com/2006/1015/1202.html


我们要把现实世界中的各种信息转换成计算机能理解的东西,这些转换后的信息就形成了数据。例如,某人的出生日期是“1987年5月23日”,他的身高是170厘米,等等。数据不仅包括数字、字母、文字和其他特殊字符组成的文本形式的数据,而且还包括图形、图像、动画、影像、声音等多媒体数据。但使用最多、最基本的仍然是文本数据。

1. MySQL的数据类型

在MySQL中有如下几种数据类型:

(1)数值型

数值是诸如32 或153.4 这样的值。MySQL 支持科学表示法,科学表示法由整数或浮点数后跟“e”或“E”、一个符号(“+”或“-”)和一个整数指数来表示。1.24E+12 和23.47e-1 都是合法的科学表示法表示的数。而1.24E12 不是合法的,因为指数前的符号未给出。

浮点数由整数部分、一个小数点和小数部分组成。整数部分和小数部分可以分别为空,但不能同时为空。

数值前可放一个负号“-”以表示负值。

(2)字符(串)型

字符型(也叫字符串型,简称串)是诸如“Hello, world!”或“一个馒头引起的血案”这样的值,或者是电话号码87398413这样的值。既可用单引号也可用双引号将串值括起来。

初学者往往分不清数值87398143和字符串87398143的区别。都是数字啊,怎么一个要用数值型,一个要用字符型呢?关键就在于:数值型的87398143是要参与计算的,比如它是金融中的一个货款总额;而字符型的87398143是不参与计算的,只是表示电话号码,这样的还有街道号码、门牌号码等等,它们都不参与计算。

(3)日期和时间型

日期和时间是一些诸如“2006-07-12”或“12:30:43”这样的值。MySQL还支持日期/时间的组合,如“2006-07-12 12:30:43”。

(4)NULL值

NULL表示未知值。比如填写表格中通讯地址不清楚留空不填写,这就是NULL值。

我们用Create Table语句创建一个表(参看前面的章节),这个表中包含列的定义。例如我们在前面创建了一个joke表,这个表中有content和writer两个列:

定义一个列的语法如下:

其中列名由col_name 给出。列名可最多包含64个字符,字符包括字母、数字、下划线及美元符号。列名可以名字中合法的任何符号(包括数字)开头。但列名不能完全由数字组成,因为那样可能使其与数据分不开。MySQL保留诸如SELECT、DELETE和CREATE这样的词,这些词不能用做列名,但是函数名(如POS 和MIN)是可以使用的。

列类型col_type表示列可存储的特定值。列类型说明符还能表示存放在列中的值的最大长度。对于某些类型,可用一个数值明确地说明其长度。而另外一些值,其长度由类型名蕴含。例如,CHAR(10) 明确指定了10个字符的长度,而TINYBLOB值隐含最大长度为255个字符。有的类型说明符允许指定最大的显示宽度(即显示值时使用多少个字符)。浮点类型允许指定小数位数,所以能控制浮点数的精度值为多少。

可以在列类型之后指定可选的类型说明属性,以及指定更多的常见属性。属性起修饰类型的作用,并更改其处理列值的方式,属性有以下类型:

(1)专用属性用于指定列。例如,UNSIGNED 属性只针对整型,而BINARY属性只用于CHAR 和VARCHAR。

(2)通用属性除少数列之外可用于任意列。可以指定NULL 或NOT NULL 以表示某个列是否能够存放NULL。还可以用DEFAULT,def_value 来表示在创建一个新行但未明确给出该列的值时,该列可赋予值def_value。def_value 必须为一个常量;它不能是表达式,也不能引用其他列。不能对BLOB 或TEXT 列指定缺省值。

如果想给出多个列的专用属性,可按任意顺序指定它们,只要它们跟在列类型之后、通用属性之前即可。类似地,如果需要给出多个通用属性,也可按任意顺序给出它们,只要将它们放在列类型和可能给出的列专用属性之后即可。

2. MySQL的列(字段)类型

数据库中的每个表都是由一个或多个列(字段)构成的。在用CREATE TABLE语句创建一个表时,要为每列(字段)指定一个类型。列(字段)的类型比数据类型更为细化,它精确地描述了给定表列(字段)可能包含的值的种类,如是否带小数、是否文字很多。

MySQL有整数和浮点数值的列类型,如表1所示。整数列类型可以有符号也可无符号。有一种特殊的属性允许整数列值自动生成,这对需要唯一序列或标识号的应用系统来说是非常有用的。



类型



说明

TINYINT 非常小的整数
SMALLINT 较小整数
MEDIUMINT 中等大小整数
INT 标准整数
BIGINT 较大整数
FLOAT 单精度浮点数
DOUBLE 双精度浮点数
DECIMAL 一个串的浮点数


表1:数值列类型
每种数值类型的名称和取值范围如表2所示。



类型说明



取值范围

TINYINT[(M)] 有符号值:-128 到127(- 27 到27 - 1)
无符号值:0到255(0 到28 - 1)
SMALLINT[(M)] 有符号值:-32768 到32767(- 215 到215 - 1)
无符号值:0到65535(0 到21 6 - 1)
MEDIUMINT[(M)] 有符号值:-8388608 到8388607(- 22 3 到22 3 - 1 )
无符号值:0到16777215(0 到22 4 - 1)
INT[(M)] 有符号值:-2147683648 到2147683647(- 231 到231- 1)
无符号值:0到4294967295(0 到232 - 1)
BIGINT[(M)] 有符号值:-9223372036854775808 到9223373036854775807(- 263到263-1)

无符号值:0到18446744073709551615(0到264 – 1)
FLOAT[(M, D)] 最小非零值:±1.175494351E - 38
DOUBLE[(M,D)] 最小非零值:±2.2250738585072014E - 308
DECIMAL (M, D) 可变;其值的范围依赖于M 和D


表2:数值列类型的取值范围


类型说明



存储需求

TINYINT[(M)] 1字节
SMALLINT[(M)] 2字节
MEDIUMINT[(M)] 3字节
INT[(M)] 4字节
BIGINT[(M)] 8字节
FLOAT[(M, D)] 4字节
DOUBLE[(M, D)] 8字节
DECIMAL (M, D) M字节(MySQL < 3.23),M+2字节(MySQL > 3.23 )


表3:数值列类型的存储需求
MySQL提供了五种整型: TINYINT、SMALLINT、MEDIUMINT、INT和BIGINT。INT为INTEGER的缩写。这些类型在可表示的取值范围上是不同的。整数列可定义为UNSIGNED从而禁用负值;这使列的取值范围为0以上。各种类型的存储量需求也是不同的。取值范围较大的类型所需的存储量较大。



MySQL 提供三种浮点类型: FLOAT、DOUBLE和DECIMAL。与整型不同,浮点类型不能是UNSIGNED的,其取值范围也与整型不同,这种不同不仅在于这些类型有最大值,而且还有最小非零值。最小值提供了相应类型精度的一种度量,这对于记录科学数据来说是非常重要的(当然,也有负的最大和最小值)。

在选择了某种数值类型时,应该考虑所要表示的值的范围,只需选择能覆盖要取值的范围的最小类型即可。选择较大类型会对空间造成浪费,使表不必要地增大,处理起来没有选择较小类型那样有效。对于整型值,如果数据取值范围较小,如人员年龄或兄弟姐妹数,则TINYINT最合适。MEDIUMINT能够表示数百万的值并且可用于更多类型的值,但存储代价较大。BIGINT在全部整型中取值范围最大,而且需要的存储空间是表示范围次大的整型INT类型的两倍,因此只在确实需要时才用。对于浮点值,DOUBLE占用FLOAT的两倍空间。除非特别需要高精度或范围极大的值,一般应使用只用一半存储代价的FLOAT型来表示数据。

在定义整型列时,可以指定可选的显示尺寸M。如果这样,M应该是一个1 到255的整数。它表示用来显示列中值的字符数。例如,MEDIUMINT(4)指定了一个具有4个字符显示宽度的MEDIUMINT列。如果定义了一个没有明确宽度的整数列,将会自动分配给它一个缺省的宽度。缺省值为每种类型的“最长”值的长度。如果某个特定值的可打印表示需要不止M个字符,则显示完全的值;不会将值截断以适合M个字符。

对每种浮点类型,可指定一个最大的显示尺寸M 和小数位数D。M 的值应该取1 到255。D的值可为0 到3 0,但是不应大于M - 2(如果熟悉ODBC 术语,就会知道M 和D 对应于ODBC 概念的“精度”和“小数点位数”)。M和D对FLOAT和DOUBLE 都是可选的,但对于DECIMAL是必须的。在选项M 和D时,如果省略了它们,则使用缺省值。

2.2字符串列类型

MySQL提供了几种存放字符数据的串类型,其类型如下:



类型名



说明

CHAR 定长字符串
VARCHAR 可变长字符串
TINYBLOB 非常小的BLOB(二进制大对象)
BLOB 小BLOB
MEDIUMBLOB 中等的BLOB
LONGBLOB 大BLOB
TINYTEXT 非常小的文本串
TEXT 小文本串
MEDIUMTEXT 中等文本串
LONGTEXT 大文本串
ENUM 枚举;列可赋予某个枚举成员
SET 集合;列可赋予多个集合成员

相关推荐

    mysql5.1中文手册.zip

    MySQL 5.1是MySQL数据库管理系统的一个重要版本,它在早期的5.x系列中提供了许多增强功能和优化,为开发者提供了更稳定、高效的数据存储和管理解决方案。本手册旨在详细介绍MySQL 5.1的各项特性和操作方法,帮助用户...

    mysql的JDBC驱动包

    在提供的压缩包"mysql的JDBC驱动包"中,你应该能找到名为`mysql-connector-java-x.x.x.jar`的文件,这里的"x.x.x"是具体的版本号。你可以将这个jar文件添加到你的项目的类路径中,或者如果你使用Maven或Gradle等构建...

    mysql8.0.15,安装配套所需的软件及Jdbc驱动jar包

    在给定的文件列表中,虽然没有明确的 JDBC 驱动 jar 包,但在实际应用中,你需要下载并添加 `mysql-connector-java-x.x.x.jar` 到你的 Java 项目的类路径中,这里的 x.x.x 是具体的版本号。 安装步骤通常包括以下几...

    mysql-connector-java-8.0.11.jar文件

    `mysql-connector-java-8.0.11.jar`是这个驱动的特定版本,8.0.11,针对的是MySQL 8.x系列的数据库。 首先,我们来深入了解一下MySQL Connector/J的基本功能。它提供了以下关键特性: 1. **连接管理**:创建并管理...

    mysql57驱动jar包

    MySQL 5.7驱动jar包的全名通常是`mysql-connector-java-5.7.x.jar`,其中`x`代表具体的次要版本号。将这个jar包添加到Java项目的类路径(ClassPath)中,即可使用Java来操作MySQL数据库。添加方法可以有多种,如在...

    MySQL常用函数大全

    - **INSERT(str, x, y, instr)**: 在字符串`str`中从位置`x`开始替换长度为`y`的子串为`instr`。 - **FIND_IN_SET(str, list)**: 查找字符串`str`是否存在于逗号分隔的列表`list`中,并返回其位置。 - **LCASE(str)/...

    MySQL常用函数的举例及例子

    在MySQL中,数学函数是处理数值数据的基本工具之一。这些函数能够帮助我们执行简单的算术运算、数值转换以及进行数学计算。 - **ABS(x)**:返回`x`的绝对值。例如,`ABS(-10)`返回10。 - **BIN(x)**:返回`x`的二...

    mysql存储过程之创建(CREATE PROCEDURE)和调用(CALL)及变量创建(DECLARE)和赋值(SET)操作方法

    DECLARE x, y INT DEFAULT 0; ``` 四、变量赋值(SET) 为变量赋值通常使用`SET`语句,例如: ```sql DECLARE total_count INT DEFAULT 0; SET total_count = 10; ``` 这里将`total_count`的值设为了10。此外,`...

    emqx配置和安装.docx

    EMQX 的消息存储可以使用 MySQL 数据库,创建一个名为 `emqx_history_20220612` 的表,表结构如下: CREATE TABLE `emqx_history_20220612` ( `msg_id` int(11) NOT NULL, `msg_body` text CHARACTER SET utf8 ...

    MySQL驱动jar包

    MySQL Connector/J是MySQL官方提供的Java驱动程序,它的全名通常是`mysql-connector-java-x.x.x.jar`,其中`x.x.x`表示版本号。在这个例子中,我们看到的是`mysql-connector-java-6.0.6.jar`,这意味着它是6.0.6版本...

    mysql-connector-java-5.1.7 jar包

    例如,如果项目中使用的是MySQL 8.x版本,应对应使用`mysql-connector-java-8.x.x.jar`,因为不同版本的MySQL数据库可能不兼容较旧的驱动。 总的来说,`mysql-connector-java-5.1.7.jar`是Java开发者连接MySQL...

    VB6连接MySQL数据库实例含驱动和源代码

    在VB6项目中,我们通常会通过引用"Microsoft ActiveX Data Objects x.x Library"来使用ADO。 1. **安装MySQL驱动**:在VB6中连接MySQL,需要MySQL的ODBC驱动(Open Database Connectivity)。这通常称为"MyODBC",...

    mysql驱动jar包

    2. **添加到项目**:将下载的jar文件(例如:`mysql-connector-java-x.x.x.jar`)添加到你的项目类路径中。对于IDE如Eclipse或IntelliJ IDEA,可以直接将jar文件导入到项目的“库”或“外部库”中。如果是命令行编译...

    PHP访问MySQL数据库函数简介

    需要注意的是,PHP 7.x 版本已经废弃了这些 MySQL 扩展,推荐使用 MySQLi 或 PDO_MySQL 扩展来替代。这些新扩展不仅提供了更丰富的功能,还支持面向对象编程风格,使得代码更加易于维护和扩展。

    命令窗口创建mysql数据库

    首先打开DOS窗口,进入MySQL安装目录下的bin子目录(例如:`C:\Program Files\MySQL\MySQL Server X.X\bin`,其中X.X代表版本号)。然后,键入以下命令: ```bash mysql -u root -p ``` 输入完成后按回车,系统会...

    mysql 批量更新及效率对比

    MySQL 批量更新是指在 MySQL 数据库中批量更新多条记录的操作。这种操作在实际应用中非常常见,例如批量更新用户信息、订单状态等。然而,批量更新的效率问题一直是一个棘手的问题。近期,我们有了大量的 MySQL 批量...

    mysql-connector-java-5.1.30-bin.zip

    对于更高版本的MySQL,可能需要更新到更匹配的驱动版本,例如`8.x`系列对应`mysql-connector-java-8.x.y.jar`。 8. **安全注意事项**: - 避免在代码中硬编码数据库凭证,可以使用环境变量或配置文件。 - 使用预...

    java开发mysql8的jdbc驱动包.rar

    在给定的压缩包"java开发mysql8的jdbc驱动包.rar"中,你应该找到了这个驱动的jar文件,例如`mysql-connector-java-x.x.x.jar`,这里的"x.x.x"代表具体的版本号。 安装和使用MySQL JDBC驱动包的步骤如下: 1. **...

    java连接mysql的jdbc包mysql-connector5.1.15

    `mysql-connector5.1.15`版本是MySQL JDBC驱动的一个较旧版本,适用于MySQL 5.x系列。随着MySQL版本的更新,驱动也进行了相应的升级,提供了更好的性能、兼容性和新特性。例如,较新的驱动版本支持SSL连接、更大的...

Global site tag (gtag.js) - Google Analytics