国产探花免费观看_亚洲丰满少妇自慰呻吟_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ā)表
主站蜘蛛池模板: 北安市| 宁化县| 黔江区| 伊春市| 遵义市| 翁牛特旗| 石阡县| 邯郸市| 屯门区| 无锡市| 石屏县| 潮安县| 叶城县| 平塘县| 台州市| 元江| 尉氏县| 宁陕县| 申扎县| 鄂托克旗| 沭阳县| 宜阳县| 治县。| 梁平县| 紫金县| 濮阳县| 铁力市| 九龙坡区| 云林县| 灌云县| 高安市| 达尔| 津南区| 电白县| 崇阳县| 台山市| 赤峰市| 成武县| 永宁县| 夏邑县| 马边|