正確理解Mysql中的列索引和多列索引_MySQL教程
推薦:如何通過(guò)配置自動(dòng)實(shí)現(xiàn)ValueList中hql語(yǔ)句的整型參數(shù)轉(zhuǎn)換通過(guò)valuelist的queryMap傳遞過(guò)來(lái)的參數(shù)默認(rèn)都為string類型,在valuelist配置文件的hql中,如果直接將該值賦給整型的字段會(huì)報(bào)錯(cuò)。一般我們會(huì)在hql中利用轉(zhuǎn)型函數(shù)來(lái)進(jìn)行處理,如下: 復(fù)制代碼 代碼如下: entry key=areasInfoAdapter bean parent=abstractHibernate30Ada
Mysql數(shù)據(jù)庫(kù)提供兩種類型的索引,如果沒(méi)正確設(shè)置,索引的利用效率會(huì)大打折扣卻完全不知問(wèn)題出在這。
復(fù)制代碼 代碼如下:CREATE TABLE test (
id INT NOT NULL,
last_name CHAR(30) NOT NULL,
first_name CHAR(30) NOT NULL,
PRIMARY KEY (id),
INDEX name (last_name,first_name)
);
以上創(chuàng)建的其實(shí)是一個(gè)多列索引,創(chuàng)建列索引的代碼如下:
CREATE TABLE test (
id INT NOT NULL,
last_name CHAR(30) NOT NULL,
first_name CHAR(30) NOT NULL,
PRIMARY KEY (id),
INDEX name (last_name),
INDEX_2 name (first_name)
);
一個(gè)多列索引可以認(rèn)為是包含通過(guò)合并(concatenate)索引列值創(chuàng)建的值的一個(gè)排序數(shù)組。 當(dāng)查詢語(yǔ)句的條件中包含last_name 和 first_name時(shí),例如:
SELECT * FROM test WHERE last_name='Kun' AND first_name='Li';
sql 會(huì)先過(guò)濾出last_name符合條件的記錄,在其基礎(chǔ)上在過(guò)濾first_name符合條件的記錄。那如果我們分別在last_name和 first_name上創(chuàng)建兩個(gè)列索引,mysql的處理方式就不一樣了,它會(huì)選擇一個(gè)最嚴(yán)格的索引來(lái)進(jìn)行檢索,可以理解為檢索能力最強(qiáng)的那個(gè)索引來(lái)檢 索,另外一個(gè)利用不上了,這樣效果就不如多列索引了。
但是多列索引的利用也是需要條件的,以下形式的查詢語(yǔ)句能夠利用上多列索引:
SELECT * FROM test WHERE last_name='Widenius';
SELECT * FROM test WHERE last_name='Widenius' AND first_name='Michael';
SELECT * FROM test WHERE last_name='Widenius' AND (first_name='Michael' OR first_name='Monty');
SELECT * FROM test WHERE last_name='Widenius' AND first_name >='M' AND first_name < 'N';
以下形式的查詢語(yǔ)句利用不上多列索引:
SELECT * FROM test WHERE first_name='Michael';
SELECT * FROM test WHERE last_name='Widenius' OR first_name='Michael';
多列建索引比對(duì)每個(gè)列分別建索引更有優(yōu)勢(shì),因?yàn)樗饕⒌迷蕉嗑驮秸即疟P空間,在更新數(shù)據(jù)的時(shí)候速度會(huì)更慢。
另外建立多列索引時(shí),順序也是需要注意的,應(yīng)該將嚴(yán)格的索引放在前面,這樣篩選的力度會(huì)更大,效率更高。
分享:Mysql建表與索引使用規(guī)范詳解本篇文章是對(duì)Mysql建表和索引使用規(guī)范進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下 一、 MySQL建表,字段需設(shè)置為非空,需設(shè)置字段默認(rèn)值。 二、 MySQL建表,字段需NULL時(shí),需設(shè)置字段默認(rèn)值,默認(rèn)值不為NULL。 三、 MySQL建表,如果字段等價(jià)于外鍵,應(yīng)在該字段加索引。 四
- MSSQL清空日志刪除日志文件
- 關(guān)于數(shù)據(jù)庫(kù)中保留小數(shù)位的問(wèn)題
- 解析mysql與Oracle update的區(qū)別
- mysql 導(dǎo)入導(dǎo)出數(shù)據(jù)庫(kù)以及函數(shù)、存儲(chǔ)過(guò)程的介紹
- MySQL——修改root密碼的4種方法(以windows為例)
- 解決MYSQL出現(xiàn)Can''t create/write to file ''#sql_5c0_0.MYD''的問(wèn)題
- 深入理解SQL的四種連接-左外連接、右外連接、內(nèi)連接、全連接
- 解析:內(nèi)聯(lián),左外聯(lián),右外聯(lián),全連接,交叉連接的區(qū)別
- mysql出現(xiàn)“Incorrect key file for table”處理方法
- mysql重裝后出現(xiàn)亂碼設(shè)置為utf8可解決
- 淺析一個(gè)MYSQL語(yǔ)法(在查詢中使用count)的兼容性問(wèn)題
- 解析MySQL中INSERT INTO SELECT的使用
MySQL教程Rss訂閱編程教程搜索
MySQL教程推薦
- MYSQL SET類型字段的SQL操作知識(shí)介紹
- SQLServer導(dǎo)出數(shù)據(jù)到MySQL實(shí)例介紹
- MySQL SELECT同時(shí)UPDATE同一張表問(wèn)題發(fā)生及解決
- mysql登錄遇到ERROR 1045問(wèn)題解決方法
- 如何用workbench導(dǎo)出mysql數(shù)據(jù)庫(kù)關(guān)系圖
- 把視頻文件直接存儲(chǔ)到mysql數(shù)據(jù)庫(kù)的方法
- SQL提示Login failed for user#039;sa#039;錯(cuò)誤的解決方案
- 網(wǎng)站模板:以數(shù)據(jù)庫(kù)字段分組顯示數(shù)據(jù)的sql語(yǔ)句
- Mysql查看版本號(hào)的五種方式介紹
- Mysql高性能備份方案解決數(shù)據(jù)不間斷訪問(wèn)
猜你也喜歡看這些
- 通過(guò)JDBC連接DB2數(shù)據(jù)庫(kù)技巧
- sql server 2008安裝過(guò)程中服務(wù)器配置出錯(cuò)解決辦法
- 剖析SQL Server2005 SQLCLR代碼安全性
- SQL Server儲(chǔ)過(guò)程加密和解密原理深入分析
- 比較SQL Server數(shù)據(jù)庫(kù)導(dǎo)入導(dǎo)出數(shù)據(jù)方式
- SQL server 2008 數(shù)據(jù)安全(備份和恢復(fù)數(shù)據(jù)庫(kù))
- 詳解SQL嵌套子查詢
- 解析SqlServer2000獲取當(dāng)前日期及格式
- 怎樣用SQL 2000 生成XML
- 怎樣讓SQL Server加速運(yùn)行
- 相關(guān)鏈接:
- 教程說(shuō)明:
MySQL教程-正確理解Mysql中的列索引和多列索引
。