本节介绍MySQL支持的数据类型,提供关于每种类型的名称、作用、格式和范围的信息。TIMETIME数据类型负责存储时间信息,支持的范围相当大,不仅足以表示标准和军用时间格式,还可以表示扩展时间间隔。注意,对于MySQL版本4.1及更新版本,不可以指定该数据类型的大小。......
2023-10-29
虽然本节下面的列表并不详尽,但这里将介绍最常用的属性,以及将在本书余下部分使用的属性。
➢ AUTO_INCREMENT
AUTO_INCREMENT属性去除了许多数据库驱动的应用程序中必要的一层逻辑:它能为新插入的行赋一个唯一的整数标识符。为列赋此属性将为每个新插入的行赋值为上一次插入的ID+I。
MySQL要求AUTO_INCREMENT属性用于作为主键的列。此外,每个表只允许有一个AUTO_INCREMENT列。AUTO INCREMENT列的示例如下:
➢ BINARY
BINARY属性只用于CHAR和VARCHAR值。当列指定了此属性时,将以区分大小写的方式排序(根据其ASCII机器值)。与之相反,忽略BINARY属性时,将使用不区分大小写的方式排序。BINARY列的示例如下:
➢ DEFAULT
DEFAULT属性确保在没有任何值可用的情况下,赋予某个常量值。这个值必须是常量,因为MySQL不允许插入函数或表达式值。此外,此属性无法用于BLOB或TEXT列。如果已经为此列指定了NULL属性,没有指定默认值时,默认值将为NULL。否则(具体的,如果指定了NOT NULL属性),默认值将依赖于字段的数据类型。DEFAULT属性的示例如下:
➢ INDEX
如果所有其他因素都相同,要加速数据库查询,使用索引通常是最重要的一个步骤。索引一个列会为该列创建一个有序的键数组,每个键指向其相应的表行。以后针对输入条件可以搜索这个有序的键数组,与搜索整个未索引的表相比,将在性能方面得到极大的提升,因为MySQL已经支持有序数组。
下面的例子展示了如何对一个用于存储员工姓氏的列进行索引:
或者,也可以利用MySQL的CREATE INDEX命令在表创建之后增加索引:
本节对前面的示例略微做了修改,这一次只索引了名字的前7个字符,因为可能不需要其他字母来区分不同的名字。由于使用较小的索引时性能更好,所以应当在实践中尽量使用小的索引。
➢ NATIONAL
NATIONAL属性只用于CHAR和VARCHAR数据类型。当指定该属性时,它确保该列使用默认字符集,而MySQL默认地已经要求使用默认字符集。简言之,提供该属性是为了保证数据库兼容性。(www.chuimin.cn)
➢ NOT NULL
NOT NULL如果将一个列定义为NOT NULL。将不允许向该列插入NULL值。建议在重要情况下始终使用NOT NULL属性,因为它提供了一个基本验证,确保已经向查询传递了所有必要的值。NOT NULL列的示例如下:
➢ NULL
简言之,NULL属性意味着指定列可以不存在值。记住,NULL精确的说法为“无”,而不是空字符串或0。为列指定NULL属性时,该列可以保持为空,而不论行中其他列是否已经填充。列会默认地指定NULL属性。一般而言,可能不想采用这种默认设置,而希望确保表不会接受空值。这是通过上面介绍的NULL的对立属性NOT NULL来实现的。
➢ PRIMARY KEY
PRIMARY KEY属性用于确保指定行的唯一性。指定为主键的列中,值不能重复,也不能为空。为指定为主键的列赋予AUTO_INCREMENT属性是很常见的,因为此列不必与行数据有任何关系,而只是作为一个唯一标识符。但是,还有另外两种方法确保记录的唯一性。
(1) 单字段主键。如果输入到数据库中的每行已经有不可修改的唯一标识符,例如部件号码或社会保险号,一般会使用单字段主键。注意,此键一旦设置就不能再修改。
(2) 多字段主键。如果记录中任何一个字段都不可能保证唯一性,就可以使用多字段主键。这时,多个字段联合起来确保唯一性。当出现这种情况时,指定一个AUTO_INCREMENT整数作为主键是个好主意,这样就不必为每次插入生成唯一标识符了。
➢ UNIQUE
赋予UNiQUE属性的列将确保所有值都有不同的值,只是NULL值可以重复。一般会指定一个列为UNiQUE,以确保该列的所有值都不同。例如,要防止多次向一个新闻订阅列表中插入相同的电子邮件地址,同时又允许该字段可以为空(NULL)。以下是指定了UNIQUE属性的列示例:
➢ ZEROFILL
ZEROFILL属性可用于任何数值类型,使所有剩余字段空间用0填充。例如,无符号INT的默认宽度为10;因此,当“零填充”的INT值为4时,将表示为0 000 000 004。ZEROFILL属性的示例如下:
根据此定义,值35678将返回为0035678。
有关MySQL数据库设计与实现的文章
本节介绍MySQL支持的数据类型,提供关于每种类型的名称、作用、格式和范围的信息。TIMETIME数据类型负责存储时间信息,支持的范围相当大,不仅足以表示标准和军用时间格式,还可以表示扩展时间间隔。注意,对于MySQL版本4.1及更新版本,不可以指定该数据类型的大小。......
2023-10-29
这一节将重点讨论促使MySQL风行的一些关键特性。接下来,还将提供有关MySQL产品两个主要里程碑版本的重要信息。庞大的开源社区:MySQL之所以如此流行和受欢迎,很大一部分功劳要归功于开源社区的积极支持。在开源社区中不仅能了解到MySQL的最新发展动态,还能快速地解决一些问题和难题。......
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
如下语法可用于创建存储过程:而如下语法用于创建存储函数:例如,来创建一个返回静态字符串的简单存储过程:仅此而已。请继续阅读,了解创建复杂的存储过程还有哪些选项。例如,能够使用PHP、Perl和Python语言创建存储过程,这意味着过程的功能只受所使用语言的限制。在编写本书时,此特点对存储过程的功能没有影响。......
2023-10-29
事务的隔离级别就是用来设置事务在读取数据时的隔离状态,提高数据并发使用效率的一种手段。事务的隔离级别由低到高可分为5个级别。MySQL默认级别,这种隔离级别可以避免“不可重复读取”,达到可重复读取。更改事务的隔离级别的语法代码如下:事务隔离级别的作用范围分为两种: 全局级:对所有的会话有效 会话级:只对当前的会话有效例如,设置会话级隔离级别为READ COMMITTED:或:设置全局级隔离级别为READ COMMITTED:......
2023-10-29
表示索引为唯一性索引。指索引的长度,必须是字符串类型才可以使用。如果在创建索引时没写索引名称,MySQL会自动用字段名作为索引名称。其中table_name是要增加索引的表名,column_list指出对哪些列进行索引,多列时各列之间用逗号分隔。另外,ALTER TABLE允许在单个语句中更改多个表,因此可以在同时创建多个索引。另外,不能用CREATE INDEX语句创建PRIMARY KEY索引。......
2023-10-29
创建视图是通过CREATE VIEW语句实现的。当视图指定为TEMPTABLE时,将在创建视图的同时创建相应的TEMPORARY表。如果为视图指定了UNDEFINED算法,当查询指示其结果和视图结果是一对一关系时,MySQL将选择TEMPTABLE。DEFINER子句确定在视图执行时将检查哪个用户账户的权限来确定是否有适当的权限执行这个视图。......
2023-10-29
相关推荐