MySQL要求AUTO_INCREMENT属性用于作为主键的列。与之相反,忽略BINARY属性时,将使用不区分大小写的方式排序。否则,默认值将依赖于字段的数据类型。简言之,提供该属性是为了保证数据库兼容性。将不允许向该列插入NULL值。建议在重要情况下始终使用NOT NULL属性,因为它提供了一个基本验证,确保已经向查询传递了所有必要的值。PRIMARY KEYPRIMARY KEY属性用于确保指定行的唯一性。......
2023-10-29
本节介绍MySQL支持的数据类型,提供关于每种类型的名称、作用、格式和范围的信息。为方便以后引用,将其分为三种类别:日期和时间、数值以及字符串。
1.日期和时间数据类型
很多类型可用来表示基于时间和日期的数据。本节介绍这些类型。
➢ DATE
DATE数据类型负责存储日期信息。虽然MySQL以标准的YYYY-MM-DD格式显示DATE值.但这些值可以使用数字或字符串来插入。例如,20040810和2004-08-10都可以接受为有效的输入。日期范围从1000-01-01到9999-12-31。
➢ DATETIME
DATETIME数据类型负责存储日期和时间信息的组合。与DATE,OATETIME值以标准格式YYYY-MM-DD HH:MM:SS存储。这些值可以使用数值或字符串来插入。例如,20080810153510和2008-08- 10 15:35:10都接受为有效输入。DATETIME的范围从1000-01-01 00:00:00到9999-12-31 23:59:59。
➢ TIME
TIME数据类型负责存储时间信息,支持的范围相当大,不仅足以表示标准和军用时间格式,还可以表示扩展时间间隔。其范围从- 838:59:59到838:59:59。
➢ TIMESTAMP[(M)][DEFAULT] [ON UPDATE]
TIMESTAMP数据类型不同于DATETIME,MySQL执行了影响TIMESTAMP数据的INSERT或UPDATE操作之后,会自动将其更新为当前的日期和时间。TIMESTAMP值显示为HH:MM:SS格式,与DATE和DATETIME数据类型一样,也可以使用数值或字符串进行赋值。TIMESTAMP值可以采用如下格式显示:YYYYMMDDHHMMSS(14位数)、YYMMDDHHMMSS(12位数)、YYYYMMDD(8位数)和YYMMDD(6位数)。TIMESTAMP的范围从1970-01-01 00:00:01到2037-12-31 23:59:59,其存储需要4个字节。
注意,对于MySQL版本4.1及更新版本,不可以指定该数据类型的大小。从版本4.1开始,TIMESTAMP列格式限制为与DATETIME相同。换言之,TIMESTAMP值始终存储为YYYY-MM-DD HH:MM:SS。
➢ YEAR[(214)]
YEAR数据类型负责存储年份特定的信息,根据上下文支持多种范围。
(1) 两位数值,1~99。范围从1~69的值转换为2001~2069的值,而范围从70~99的值转换为范围1970~1999的值。
(2) 四位数值,1901~2155。
(3) 两位数字符串,00~99。范围从00~69的值转换为2000~2069的值,而范围从70~99的值转换为范围1970~1999的值。
(4) 四位数字符串,1901~2155。
2.数值数据类型
很多类型可用来表示数值数据。本节介绍这些类型。
➢ BOOL和BOOLEAN
BOOL和BOOLEAN只是TINYINT(I)的别名,用于赋值0或1。该数据类型是在版本4.1.0添加的。
➢ BIGINT[(H)]
BIGINT数据类型提供了MySQL最大的整数范围,支持的有符号数范围从-9 223 372 036 854 775 808—9 223 372 036 854 775 807,无符号数范围从0—18 446 744 073 709 551 615。
➢ INT[(H)][UNSIGNED] [ZEROFILL]
INT数据类型提供了MySQL的第二大整数范围,支持的有符号数范围从-2 147 483 648~2 147 483 647,无符号数范围从0~4 294 967 295。
➢ MEDIUMINT[(H)][UNSIGNED] [ZEROFILL]
MEDIUMINT数据类型提供了MySQL的第三大整数范围,支持的有符号数范围从-8 388 608~8 388 607,无符号数范围从0~16 777 215。
➢ SMALLINT[(H)][UNSIGNED][ZEROFILL]
SMALLINT数据类型提供了MySQL的第四大整数范围,支持的有符号数范围从-32 768~32 767,无符号数范围从0~65 535。
➢ TINYINT[(H)][UNSIGNED] [ZEROFILL]
TINYINT数据类型是MySQL最小的整数范围,支持的有符号数范围从-128~127,无符号数范围从O~255。
➢ DECIMAL([M[.D]]) [UNSIGNED] [ZEROFILL]
DECIMAL数据类型是存储为字符串的浮点数,支持的有符号数范围从-1.7976931348623157E+308~-2.2250738585072014E-308,无符号数范围从2.2250738585072014E-308—1.7976931348623157E+308。在确定数值的总大小时,忽略小数点和负号。(www.chuimin.cn)
➢ DOUBLE([M,D]) [UNSIGNED] [ZEROFILL]
OOUBLE数据类型是双精度浮点数,支持的有符号数范围从-1.7976931348623157E+308~-2.2250738585072014E-308,无符号数范围从2.2250738585072014E-308~1.7976931348623157E+ 308。
➢ FLOAT([M.D]) [UNSIGNED] [ZEROFILL]
这种FLOAT数据类型变体是MySQL的单精度浮点数表示形式,支持的有符号数范围从-3.402823466E+38~-1.175494351E-38,无符号数范围从1.175494351E-38~3.402823466E+38。
➢ FLOAT (precision) [UNSIGNED] [ZEROFILL]
这种FLOAT数据类型变体为ODBC兼容性而提供。其精度对于单精度可以从1~24,对于双精度为从25~53。范围与前面FLOAT定义的相同。
3.字符串数据类型
有很多类型可用来表示字符串数据。本节将介绍这些类型。
➢ [NATIONAL] .CHAR(Length) [BINARY l ASCII l UNICODE]
CHAR数据类型为MySQL提供了固定长度的字符串表示形式,支持最大255个字符。如果插入的字符串不足Length空间,剩余部分将填充为空白。在获取时,将忽略这些空白。如果Length是一个字符,则用户可以忽略长度引用,只使用CHAR。还可以指定零长度的CHAR并有NOT NULL属性,它只允许NULL或“”。提供NATIONAL属性是出于兼容性原因,因为SQL-99通过这个属性来指定应该对列使用默认字符集,而MySQL已经默认地要求使用默认字符集。给出BINARY属性使该列的值以区分大小写的方式排序,忽略该属性将以不区分大小写的方式排序。
自版本4.1.0开始,如果Length大于255,该列会自动转换为能够存储指定长度的最小的TEXT类型。同时自版本4.1.0开始,如果包括ASCII属性,将导致对列应用Latin 1字符集。最后一点,自版本4.1.1开始,如果包括UNICODE属性,将导致对列应用ucs2字符集。
➢ [NATIONAL] VARCHAR(Length)[BINARY]
VARCHAR数据类型是MySQL的可变长度字符串表示形式,版本5.0.3支持的长度为从0~65536个字符,版本4.0.2支持0~255个字符,版本4.0.2之前支持1~255个字符。提供NATIONAL属性是出于兼容性原因,因为SQL-99通过此属性来指定应该对列使用默认字符集,而MySQL已经默认要求使用默认字符集。给出BINARY属性使该列的值以区分大小写的方式排序;忽略该属性将以不区分大小写的方式排序。在历史上,VARCHAR不存储尾部的空白;但是,自版本5.0.3开始,出于标准兼容性的考虑,尾部的空白也会存储。
➢ LONGBLOB
LONGBLOB数据类型是MySQL最大的二进制字符串表示形式,支持最大长度4 294 967 295个字符。
➢ LONGTEXT
LONGTEXT数据类型是MySQL最大的非二进制字符串表示形式.支持最大长度4 294 967 295个字符。
➢ MEDIUMBLOB
MEDIUMBLOB数据类型是MySQL的第二大二进制字符串表示形式,支持最多16 777 215个字符。
➢ MEDIUMTEXT
MEDIUMTEXT数据类型是MySQL的第二大非二进制文本字符串,能够存储最大长度16 777 215个字符。
➢ BLOB
BLOB数据类型是MySQL第三大二进制字符串表示形式,支持最大长度65 535个字符。
➢ TEXT
TEXT数据类型是MySQL第三大非二进制字符串表示形式,支持最大长度65 535个字符。
➢ TINYBLOB
TINYBLOB数据类型是MySQL最,J、的二进制字符串表示形式,支持最大长度255个字符。
➢ TINYTEXT
TINYTEXT数据类型是MySQL最小的非二进制字符串表示形式,支持最大长度255个字符。
➢ ENUM(“memberl”,”member2”…”member65.535”)
ENUM数据类型为最多存储一组预定义值中的某一个成员提供了一种方法,这组值最多包括65535个不同成员。成员的选择限制为列定义中声明的值。如果列声明包括NULL属性,则NULL将认为是一个有效值,并且是默认值。如果声明了NOT NULL,则列表的第一个成员是默认值。
➢ SET(“memberl”,”member2”…,”member64”)
SET数据类型为指定一组预定义值中的零个或多个值提供了一种方法,这组值最多包括64个成员。值的选择限制为列定义中声明的值。存储需求是1、2、3、4或8个值,这取决于成员的数目。可以使用公式(N+7)/8确定确切的需求,这里Ⅳ是集合大小。
有关MySQL数据库设计与实现的文章
MySQL要求AUTO_INCREMENT属性用于作为主键的列。与之相反,忽略BINARY属性时,将使用不区分大小写的方式排序。否则,默认值将依赖于字段的数据类型。简言之,提供该属性是为了保证数据库兼容性。将不允许向该列插入NULL值。建议在重要情况下始终使用NOT NULL属性,因为它提供了一个基本验证,确保已经向查询传递了所有必要的值。PRIMARY KEYPRIMARY KEY属性用于确保指定行的唯一性。......
2023-10-29
这一节将重点讨论促使MySQL风行的一些关键特性。接下来,还将提供有关MySQL产品两个主要里程碑版本的重要信息。庞大的开源社区:MySQL之所以如此流行和受欢迎,很大一部分功劳要归功于开源社区的积极支持。在开源社区中不仅能了解到MySQL的最新发展动态,还能快速地解决一些问题和难题。......
2023-10-29
向表中插入数据通过INSERT命令来完成,该命令的语法格式如下:“insert …values”这种格式是目前最常用的,下面是对该格式中各属性的介绍。table_name:要插入数据的表名。ON DUPLICATE KEY UPDATE:当插入的记录会引发主键冲突或者违反唯一约束时,就会对发生冲突的列进行更新操作,使用该条件的前提是要插入的表存在主键或唯一索引。图4.18使用ON DUPLICATE KEY UPDATE条件的例子2.使用“insert…set”插入数据使用“insert…set”格式的语句可根据明确指定的值插入数据。......
2023-10-29
在MySQL已经成功启动的前提下,输入以下命令:这样一个名为shop的数据库就创建成功了。图4.1查看系统内数据库在图4.1中,第一个数据库information_schema是MySQL自带的,该数据库存储了所有MySQL服务器管理的数据库信息,比如数据库名、数据库的表、表的数据类型及访问权限等。图4.2非法的数据库名如果要创建的数据库名字在MySQL中已经存在,也会发生错误。......
2023-10-29
由于不是所有的用户都习惯于用命令行程序,所以开发了GUI程序。下面就介绍一下SQLyog。SQLyog是业界著名的Webyog公司出品的一款简洁高效、功能强大的图形化MySQL数据库管理工具。使用SQLyog可以快速直观地让您从世界的任何角落通过网络来维护远端的MySQL数据库。图2.19SQLyog连接数据库进入管理界面,如图2.20所示。图2.22SQLyog查询视图结果视图,如图2.23所示。图2.23SQLyog结果视图数据库选择、常用工具栏,如图2.24所示。图2.25SQLyog菜单栏SQLyog常用技巧: Ctrl+Enter代码提示。......
2023-10-29
创建视图是通过CREATE VIEW语句实现的。当视图指定为TEMPTABLE时,将在创建视图的同时创建相应的TEMPORARY表。如果为视图指定了UNDEFINED算法,当查询指示其结果和视图结果是一对一关系时,MySQL将选择TEMPTABLE。DEFINER子句确定在视图执行时将检查哪个用户账户的权限来确定是否有适当的权限执行这个视图。......
2023-10-29
如下语法可用于创建存储过程:而如下语法用于创建存储函数:例如,来创建一个返回静态字符串的简单存储过程:仅此而已。请继续阅读,了解创建复杂的存储过程还有哪些选项。例如,能够使用PHP、Perl和Python语言创建存储过程,这意味着过程的功能只受所使用语言的限制。在编写本书时,此特点对存储过程的功能没有影响。......
2023-10-29
事务的隔离级别就是用来设置事务在读取数据时的隔离状态,提高数据并发使用效率的一种手段。事务的隔离级别由低到高可分为5个级别。MySQL默认级别,这种隔离级别可以避免“不可重复读取”,达到可重复读取。更改事务的隔离级别的语法代码如下:事务隔离级别的作用范围分为两种: 全局级:对所有的会话有效 会话级:只对当前的会话有效例如,设置会话级隔离级别为READ COMMITTED:或:设置全局级隔离级别为READ COMMITTED:......
2023-10-29
相关推荐