新聞中心

基本語(yǔ)法
MySQL 提供了三種創(chuàng)建索引的方法:
1) 使用 CREATE INDEX 語(yǔ)句
可以使用專門用于創(chuàng)建索引的 CREATE INDEX 語(yǔ)句在一個(gè)已有的表上創(chuàng)建索引,但該語(yǔ)句不能創(chuàng)建主鍵。
語(yǔ)法格式:
CREATE <索引名> ON <表名> (<列名> [<長(zhǎng)度>] [ ASC | DESC])
語(yǔ)法說(shuō)明如下:
-
<索引名>:指定索引名。一個(gè)表可以創(chuàng)建多個(gè)索引,但每個(gè)索引在該表中的名稱是唯一的。 -
<表名>:指定要?jiǎng)?chuàng)建索引的表名。 -
<列名>:指定要?jiǎng)?chuàng)建索引的列名。通??梢钥紤]將查詢語(yǔ)句中在 JOIN 子句和 WHERE 子句里經(jīng)常出現(xiàn)的列作為索引列。 -
<長(zhǎng)度>:可選項(xiàng)。指定使用列前的 length 個(gè)字符來(lái)創(chuàng)建索引。使用列的一部分創(chuàng)建索引有利于減小索引文件的大小,節(jié)省索引列所占的空間。在某些情況下,只能對(duì)列的前綴進(jìn)行索引。索引列的長(zhǎng)度有一個(gè)最大上限 255 個(gè)字節(jié)(MyISAM 和 InnoDB 表的最大上限為 1000 個(gè)字節(jié)),如果索引列的長(zhǎng)度超過(guò)了這個(gè)上限,就只能用列的前綴進(jìn)行索引。另外,BLOB 或 TEXT 類型的列也必須使用前綴索引。 -
ASC|DESC:可選項(xiàng)。ASC指定索引按照升序來(lái)排列,DESC指定索引按照降序來(lái)排列,默認(rèn)為ASC。
2) 使用 CREATE TABLE 語(yǔ)句
索引也可以在創(chuàng)建表(CREATE TABLE)的同時(shí)創(chuàng)建。在 CREATE TABLE 語(yǔ)句中添加以下語(yǔ)句。語(yǔ)法格式:
CONSTRAINT PRIMARY KEY [索引類型] (<列名>,…)
在 CREATE TABLE 語(yǔ)句中添加此語(yǔ)句,表示在創(chuàng)建新表的同時(shí)創(chuàng)建該表的主鍵。
語(yǔ)法格式:
KEY | INDEX [<索引名>] [<索引類型>] (<列名>,…)
在 CREATE TABLE 語(yǔ)句中添加此語(yǔ)句,表示在創(chuàng)建新表的同時(shí)創(chuàng)建該表的索引。
語(yǔ)法格式:
UNIQUE [ INDEX | KEY] [<索引名>] [<索引類型>] (<列名>,…)
在 CREATE TABLE 語(yǔ)句中添加此語(yǔ)句,表示在創(chuàng)建新表的同時(shí)創(chuàng)建該表的唯一性索引。
語(yǔ)法格式:
FOREIGN KEY <索引名> <列名>
在 CREATE TABLE 語(yǔ)句中添加此語(yǔ)句,表示在創(chuàng)建新表的同時(shí)創(chuàng)建該表的外鍵。
在使用 CREATE TABLE 語(yǔ)句定義列選項(xiàng)的時(shí)候,可以通過(guò)直接在某個(gè)列定義后面添加 PRIMARY KEY 的方式創(chuàng)建主鍵。而當(dāng)主鍵是由多個(gè)列組成的多列索引時(shí),則不能使用這種方法,只能用在語(yǔ)句的最后加上一個(gè) PRIMARY KRY(<列名>,…) 子句的方式來(lái)實(shí)現(xiàn)。
3) 使用 ALTER TABLE 語(yǔ)句
CREATE INDEX 語(yǔ)句可以在一個(gè)已有的表上創(chuàng)建索引,ALTER TABLE 語(yǔ)句也可以在一個(gè)已有的表上創(chuàng)建索引。在使用 ALTER TABLE 語(yǔ)句修改表的同時(shí),可以向已有的表添加索引。具體的做法是在 ALTER TABLE 語(yǔ)句中添加以下語(yǔ)法成分的某一項(xiàng)或幾項(xiàng)。
語(yǔ)法格式:
ADD INDEX [<索引名>] [<索引類型>] (<列名>,…)
在 ALTER TABLE 語(yǔ)句中添加此語(yǔ)法成分,表示在修改表的同時(shí)為該表添加索引。
語(yǔ)法格式:
ADD PRIMARY KEY [<索引類型>] (<列名>,…)
在 ALTER TABLE 語(yǔ)句中添加此語(yǔ)法成分,表示在修改表的同時(shí)為該表添加主鍵。
語(yǔ)法格式:
ADD UNIQUE [ INDEX | KEY] [<索引名>] [<索引類型>] (<列名>,…)
在 ALTER TABLE 語(yǔ)句中添加此語(yǔ)法成分,表示在修改表的同時(shí)為該表添加唯一性索引。
語(yǔ)法格式:
ADD FOREIGN KEY [<索引名>] (<列名>,…)
在 ALTER TABLE 語(yǔ)句中添加此語(yǔ)法成分,表示在修改表的同時(shí)為該表添加外鍵。
創(chuàng)建普通索引
創(chuàng)建普通索引時(shí),通常使用 INDEX 關(guān)鍵字。
例 1
創(chuàng)建一個(gè)表 tb_stu_info,在該表的 height 字段創(chuàng)建普通索引。輸入的 SQL 語(yǔ)句和執(zhí)行過(guò)程如下所示。
mysql> CREATE TABLE tb_stu_info
-> (
-> id INT NOT NULL,
-> name CHAR(45) DEFAULT NULL,
-> dept_id INT DEFAULT NULL,
-> age INT DEFAULT NULL,
-> height INT DEFAULT NULL,
-> INDEX(height)
-> );
Query OK,0 rows affected (0.40 sec)
mysql> SHOW CREATE TABLE tb_stu_info\G
*************************** 1. row ***************************
Table: tb_stu_info
Create Table: CREATE TABLE `tb_stu_info` (
`id` int(11) NOT NULL,
`name` char(45) DEFAULT NULL,
`dept_id` int(11) DEFAULT NULL,
`age` int(11) DEFAULT NULL,
`height` int(11) DEFAULT NULL,
KEY `height` (`height`)
) ENGINE=InnoDB DEFAULT CHARSET=gb2312
1 row in set (0.01 sec)
創(chuàng)建唯一索引
創(chuàng)建唯一索引,通常使用 UNIQUE 參數(shù)。
例 2
創(chuàng)建一個(gè)表 tb_stu_info2,在該表的 id 字段上使用 UNIQUE 關(guān)鍵字創(chuàng)建唯一索引。輸入的 SQL 語(yǔ)句和執(zhí)行過(guò)程如下所示。
mysql> CREATE TABLE tb_stu_info2
-> (
-> id INT NOT NULL,
-> name CHAR(45) DEFAULT NULL,
-> dept_id INT DEFAULT NULL,
-> age INT DEFAULT NULL,
-> height INT DEFAULT NULL,
-> UNIQUE INDEX(height)
-> );
Query OK,0 rows affected (0.40 sec)
mysql> SHOW CREATE TABLE tb_stu_info2\G
*************************** 1. row ***************************
Table: tb_stu_info2
Create Table: CREATE TABLE `tb_stu_info2` (
`id` int(11) NOT NULL,
`name` char(45) DEFAULT NULL,
`dept_id` int(11) DEFAULT NULL,
`age` int(11) DEFAULT NULL,
`height` int(11) DEFAULT NULL,
UNIQUE KEY `height` (`height`)
) ENGINE=InnoDB DEFAULT CHARSET=gb2312
1 row in set (0.00 sec)網(wǎng)頁(yè)名稱:MySQL創(chuàng)建索引(CREATEINDEX)
文章起源:http://www.dlmjj.cn/article/dhsghdd.html


咨詢
建站咨詢
