資料庫sql指令碼編寫規範

2021-08-28 11:39:26 字數 2111 閱讀 7101

① 對查詢進行優化,應盡量避免全表掃瞄,首先應考慮在 where 及 order by 涉及的列上建立索引。

① 應盡量避免在 where 子句中對字段進行 null 值判斷,否則將導致引擎放棄使用索引而進行全表掃瞄,如:select id from t where num is null可以在num上設定預設值0,確保表中num列沒有null值,然後這樣查詢:select id from t where num=0。

② 應盡量避免在 where 子句中使用!=或<>操作符,否則引擎將放棄使用索引而進行全表掃瞄。

③ 應盡量避免在 where 子句中使用or 來連線條件,否則將導致引擎放棄使用索引而進行全表掃瞄,如:select id from t where num=10 or num=20可以這樣查詢:select id from t where num=10 union all select id from t where num=20。

④ in 和 not in 也要慎用,否則會導致全表掃瞄,如:select id from t where num in(1,2,3) 對於連續的數值,能用 between 就不要用 in 了:select id from t where num between 1 and 3。

⑤ 下面的查詢也將導致全表掃瞄:select id from t where name like 『%李%』若要提高效率,可以考慮全文檢索。

⑥ 如果在 where 子句中使用引數,也會導致全表掃瞄。因為sql只有在執行時才會解析區域性變數,但優化程式不能將訪問計畫的選擇推遲到執行時;它必須在編譯時進行選擇。然 而,如果在編譯時建立訪問計畫,變數的值還是未知的,因而無法作為索引選擇的輸入項。如下面語句將進行全表掃瞄:select id from t where num=@num可以改為強制查詢使用索引:select id from t with(index(索引名)) where num=@num

⑦ 應盡量避免在 where 子句中對字段進行表示式操作,這將導致引擎放棄使用索引而進行全表掃瞄。如:select id from t where num/2=100應改為:select id from t where num=1002

⑧ 應盡量避免在where子句中對字段進行函式操作,這將導致引擎放棄使用索引而進行全表掃瞄。如:select id from t where substring(name,1,3)=』abc』 ,name以abc開頭的id應改為:select id from t where name like 『abc%』

⑨ 不要在 where 子句中的「=」左邊進行函式、算術運算或其他表示式運算,否則系統將可能無法正確使用索引。

⑩ 在使用索引字段作為條件時,如果該索引是復合索引,那麼必須使用到該索引中的第乙個字段作為條件時才能保證系統使用該索引,否則該索引將不會被使用,並且應盡可能的讓字段順序與索引順序相一致。

⑪ 很多時候用 exists 代替 in 是乙個好的選擇:select num from a where num in(select num from b)用下面的語句替換:select num from a where exists(select 1 from b where num=a.num)

⑫ 索引並不是越多越好,索引固然可 以提高相應的 select 的效率,但同時也降低了 insert 及 update 的效率,因為 insert 或 update 時有可能會重建索引,所以怎樣建索引需要慎重考慮,視具體情況而定。乙個表的索引數最好不要超過6個,若太多則應考慮一些不常使用到的列上建的索引是否有必要

⑬ 盡量使用數字型字段,若只含數值資訊的字段盡量不要設計為字元型,這會降低查詢和連線的效能,並會增加儲存開銷。這是因為引擎在處理查詢和連線時會逐個比較字串中每乙個字元,而對於數字型而言只需要比較一次就夠了

⑭ 盡可能的使用 varchar/nvarchar 代替 char/nchar ,因為首先變長字段儲存空間小,可以節省儲存空間,其次對於查詢來說,在乙個相對較小的字段內搜尋效率顯然要高些

任何地方都不要使用 select * from t ,用具體的字段列表代替「」,不要返回用不到的任何字段

① 盡量避免使用游標,因為游標的效率較差,如果游標操作的資料超過1萬行,那麼就應該考慮改寫。

4.常規優化方法

① 盡量避免大事務操作,提高系統併發能力。

② 盡量避免向客戶端返回大資料量,若資料量過大,應該考慮相應需求是否合理

資料庫sql編寫規範

一 dml語句 select語句必須指定具體欄位名稱,禁止寫成 因為select 會將不該讀的資料也從mysql裡讀出來,造成磁碟和網絡卡壓力,尤其在有text或者blob欄位的時候。select語句不要使用union,推薦使用union all,並且union子句個數限制在5個以內。因為union...

資料庫架構更新Sql語句編寫規範

l 建立資料庫表 下例顯示 pubs 資料庫中所建立的三個表 jobs employee 和publishers 的完整表定義,其中包含所有的約束定義。create table 表名 欄位名1 資料型別 是否允許為 null,欄位名2 資料型別 是否允許為 null 例如 create table ...

編寫資料庫指令碼

發表日期 2000 年 1 月 10 日 我在 if it moves,script it 英文 這篇文章中曾談到,如何使用 windows script host wsh windows 指令碼主機 管理 windows 和 windows 中的應用程式。文中的大多數示例都是基於管理 window...