国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數據庫 > MySQL > 正文

教你編寫高質量 高性能的MySQL語法

2024-07-25 19:09:43
字體:
來源:轉載
供稿:網友

在應用系統(tǒng)開發(fā)初期,由于開發(fā)數據庫數據比較少,對于查詢SQL語句,復雜視圖的的編寫等體會不出SQL語句各種寫法的性能優(yōu)劣,但是如果將應用系統(tǒng)提交實際應用后,隨著數據庫中數據的增加,系統(tǒng)的響應速度就成為目前系統(tǒng)需要解決的最主要的問題之一。系統(tǒng)優(yōu)化中一個很重要的方面就是SQL語句的優(yōu)化。對于海量數據,劣質SQL語句和優(yōu)質SQL語句之間的速度差別可以達到上百倍,可見對于一個系統(tǒng)不是簡單地能實現其功能就可,而是要寫出高質量的SQL語句,提高系統(tǒng)的可用性。

  在多數情況下,Oracle使用索引來更快地遍歷表,優(yōu)化器主要根據定義的索引來提高性能。但是,如果在SQL語句的where子句中寫的SQL代碼不合理,就會造成優(yōu)化器刪去索引而使用全表掃描,一般就這種SQL語句就是所謂的劣質SQL語句。在編寫SQL語句時我們應清楚優(yōu)化器根據何種原則來刪除索引,這有助于寫出高性能的SQL語句。

  SQL語句編寫注意問題

  下面就某些SQL語句的where子句編寫中需要注意的問題作詳細介紹。在這些where子句中,即使某些列存在索引,但是由于編寫了劣質的SQL,系統(tǒng)在運行該SQL語句時也不能使用該索引,而同樣使用全表掃描,這就造成了響應速度的極大降低。

  1. IS NULL 與 IS NOT NULL

  不能用null作索引,任何包含null值的列都將不會被包含在索引中。即使索引有多列這樣的情況下,只要這些列中有一列含有null,該列就會從索引中排除。也就是說如果某列存在空值,即使對該列建索引也不會提高性能。

  任何在where子句中使用is null或is not null的語句優(yōu)化器是不允許使用索引的。

  2. 聯(lián)接列

  對于有聯(lián)接的列,即使最后的聯(lián)接值為一個靜態(tài)值,優(yōu)化器是不會使用索引的。我們一起來看一個例子,假定有一個職工表(employee),對于一個職工的姓和名分成兩列存放(FIRST_NAME和LAST_NAME),現在要查詢一個叫比爾.克林頓(Bill Cliton)的職工。

  下面是一個采用聯(lián)接查詢的SQL語句,

select * from employss
where
first_name||''||last_name ='Beill Cliton'

  上面這條語句完全可以查詢出是否有Bill Cliton這個員工,但是這里需要注意,系統(tǒng)優(yōu)化器對基于last_name創(chuàng)建的索引沒有使用。

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 潞城市| 漳州市| 德阳市| 沛县| 丹东市| 梅州市| 盐亭县| 云龙县| 尚志市| 白银市| 黑水县| 双江| 香格里拉县| 梁平县| 高邑县| 轮台县| 怀集县| 广东省| 扬州市| 嘉禾县| 高州市| 池州市| 青阳县| 磴口县| 宜良县| 阿拉善左旗| 新乡市| 托里县| 措勤县| 阿拉善左旗| 安义县| 巫溪县| 营山县| 砚山县| 仁怀市| 虎林市| 出国| 沁阳市| 沅陵县| 望城县| 扶余县|