




版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
MSSQL腳本編碼規(guī)范福州星網(wǎng)視易信息系統(tǒng)有限公司更新記錄:版本作者日期內(nèi)容1.0黃晨東2023.09.09SQL腳本編寫規(guī)范2.0蔡炆炆2023.10.15基于1.0版本進(jìn)行補(bǔ)充和整理?目錄TO(shè)C\o"1-3"\h\z\uHYPERLINK\l"_Toc"Transact-SQL編程規(guī)范?PAGEREF_Toc\h1HYPERLINK\l"_Toc"一、?概述?PAGEREF_Toc\h1HYPERLINK\l"_Toc"1. 基本原則?PAGEREF_Toc\h1HYPERLINK2. 基本規(guī)范?PAGEREF_Toc\h1HYPERLINK\l"_Toc"二、?對(duì)象命名 PAGEREF_Toc\h1HYPERLINK\l"_Toc"1.?數(shù)據(jù)庫 PAGEREF_Toc\h1HYPERLINK\l"_Toc"2. 數(shù)據(jù)庫文獻(xiàn)?PAGEREF_Toc\h14.?數(shù)據(jù)視圖 PAGEREF_Toc\h2HYPERLINK\l"_Toc"5. 數(shù)據(jù)列?PAGEREF_Toc\h2HYPERLINK\l"_Toc"6.?存儲(chǔ)過程 PAGEREF_Toc\h2HYPERLINK\l"_Toc"7.?函數(shù) PAGEREF_Toc\h3HYPERLINK\l"_Toc"8.?用戶定義數(shù)據(jù)類型?PAGEREF_Toc\h3HYPERLINK\l"_Toc"9.?主鍵、索引 PAGEREF_Toc\h3HYPERLINK三、 參數(shù)命名?PAGEREF_Toc\h3HYPERLINK\l"_Toc"1.?數(shù)據(jù)列參數(shù) PAGEREF_Toc\h3HYPERLINK\l"_Toc"2. 非數(shù)據(jù)列參數(shù) PAGEREF_Toc\h4HYPERLINK\l"_Toc"3.?常用字段命名 PAGEREF_Toc\h4HYPERLINK四、?SQL編寫?PAGEREF_Toc\h4HYPERLINK\l"_Toc"1. 大小寫?PAGEREF_Toc\h4HYPERLINK\l"_Toc"2.?存儲(chǔ)格式 PAGEREF_Toc\h4HYPERLINK\l"_Toc"3. 類型選擇?PAGEREF_Toc\h4HYPERLINK4. 默認(rèn)值?PAGEREF_Toc\h5HYPERLINK6. 使用“'”?PAGEREF_Toc\h5HYPERLINK\l"_Toc"7. 語句縮進(jìn)?PAGEREF_Toc\h5HYPERLINK9.?語句分割?PAGEREF_Toc\h5HYPERLINK\l"_Toc"10. 使用“*” PAGEREF_Toc\h5HYPERLINK\l"_Toc"11. 表名別名 PAGEREF_Toc\h5HYPERLINK13. 數(shù)值比較?PAGEREF_Toc\h6HYPERLINK14.?排序 PAGEREF_Toc\h6HYPERLINK15.?Unicode字符串 PAGEREF_Toc\h6HYPERLINK16. BEGIN...END塊 PAGEREF_Toc\h6HYPERLINK\l"_Toc"17.?TOP子句 PAGEREF_Toc\h618.?TRANSACTION編寫 PAGEREF_Toc\h6HYPERLINK2. TRANSACTION注釋 PAGEREF_Toc\h7Transact-SQL編程規(guī)范概述本規(guī)范重要規(guī)定SQL腳本在書寫過程中所應(yīng)遵循的規(guī)則及注意事項(xiàng)。編寫該規(guī)范的目的是使公司軟件開發(fā)人員的源代碼書寫習(xí)慣保持一致。這樣做可以使每一個(gè)成員都可以理解其它成員的代碼,以便于源代碼的二次開發(fā)記憶系統(tǒng)的維護(hù)?;驹瓌t以大小寫敏感編寫SQL語句。
盡量使用Unicode數(shù)據(jù)類型。?優(yōu)先使用連接代替子查詢或嵌套查詢。?盡量使用參數(shù)化SQL查詢代替語句拼接SQL查詢。?盡量使用存儲(chǔ)過程代替SQL語句。嚴(yán)禁使用[拼音]+[英語]的方式來命名SQL對(duì)象或變量。?嚴(yán)禁使用觸發(fā)器。?嚴(yán)禁在表間創(chuàng)建外鍵關(guān)系。嚴(yán)禁創(chuàng)建自增長(zhǎng)主鍵列基本規(guī)范采用Pascal樣式命名數(shù)據(jù)庫對(duì)象。大寫T-SQL語言的所有關(guān)鍵字,謂詞和系統(tǒng)函數(shù)。Pascal大小寫:組成標(biāo)記符的每個(gè)單詞的首字母大寫,其余字母小寫的書寫約定。對(duì)于縮寫的雙字母單詞,規(guī)定所有大寫。例如:ApplicationException
ID對(duì)象命名數(shù)據(jù)庫命名格式為[項(xiàng)目英文名稱]。
示例:AdventureWorks數(shù)據(jù)庫文獻(xiàn)數(shù)據(jù)文獻(xiàn):[數(shù)據(jù)庫名稱]+_Data.mdf?日記文獻(xiàn):[數(shù)據(jù)庫名稱]+_Log.ldf?示例:AdventureWorks_Data.mdf
AdventureWorks_Log.ldf數(shù)據(jù)表命名格式為BL_TBL_+[表名]。
示例:BL_TBL_Employee
BL_TBL_Product
表名以英文單數(shù)命名。
示例:使用BL_TBL_Product而不是BL_TBL_Products數(shù)據(jù)視圖命名格式為BL_V_+[視圖名稱]。
示例:BL_V_Employee
BL_V_SalesPerson數(shù)據(jù)列列名稱命名采用英文單詞或縮寫,英文單詞只來自于具體業(yè)務(wù)定義,盡量表達(dá)清楚含義。命名格式為[列名稱]。?示例:AddressID?
PostalCode?盡量避免使用拼音命名,假如不可避免,對(duì)于比較短的列名,采用拼音全寫,假如拼音列名比較復(fù)雜,可以采用首個(gè)字用全拼,其它字用首字母大寫表達(dá)。
示例:寧波Ningbo
經(jīng)營(yíng)方式JingYFS存儲(chǔ)過程命名格式為BL_HV_+[存儲(chǔ)過程名稱]。
示例:BL_HV_GetUser?
BL_HV_AddUser每個(gè)過程必須要有兩個(gè)輸出參數(shù)@ErrorCode和@ErrorMessage。存儲(chǔ)過程書寫格式如下:ifexists(select1fromsysobjectswhereid=object_id(‘bl_hv_Checkout’))dropprocedurebl_hv_Checkoutgocreat(yī)eprocedureCheckout(….@ErrorCodeintoutput,--返回錯(cuò)誤代碼0表達(dá)成功非0表達(dá)失敗@ErrorMessagevarchar(100)output--返回錯(cuò)誤信息)asdeclare@checkoutidint,--變量聲明在此處…begin…endgo函數(shù)命名格式為BL_Fn_+[函數(shù)名]。
示例:BL_Fn_GetUser系統(tǒng)函數(shù)使用所有大寫。?示例:SELECTISNULL(@LastName,'Unknownlastname');
GETDATE()用戶定義數(shù)據(jù)類型命名格式為[自定義數(shù)據(jù)類型名稱]。
示例:Flag
NameStyle主鍵、索引主鍵:PK_[表名稱]_[主鍵];假如是組合主鍵,使用PK_[表名]_[主鍵1]_[主鍵2]。
示例:PK_BL_TBL_Store_CustomerID?
PK_BL_TBL_StoreContact_CustomerID_ContactID
聚集索引:PK_[表名稱]_[主鍵];假如是組合主鍵,使用PK_[表名]_[主鍵1]_[主鍵2]。
示例:PK_Store_CustomerID
PK_StoreContact_CustomerID_ContactID?唯一非聚集索引:AK_[表名稱]_[列名稱]。?示例:AK_Store_rowguid
不唯一非聚集索引:PK_[表名稱]_[列名稱]。
示例:IX_Store_SalesPersonI(lǐng)D
主XML索引:PXML_[表名稱]_[Xml類型列名稱]。
示例:PXML_Store_Demographics參數(shù)命名
數(shù)據(jù)列參數(shù)命名格式為@+[列名稱]。
示例:@Employee(cuò)ID?在列名不符合Pascal樣式時(shí)(初期遺留系統(tǒng)),例如使用所有大寫的列名稱,或使用“_”進(jìn)行連接的字段名稱,參數(shù)名稱定義使用@+[列名稱],這里的列名稱盡量符合Pascal樣式命名。非數(shù)據(jù)列參數(shù)在參數(shù)無法跟列名稱進(jìn)行關(guān)聯(lián)時(shí),使用可以反映該參數(shù)功能的英文單詞或單詞組合,采用Pascal樣式命名。
示例:@ErrorID?
@Flag常用字段命名這里的常用字段是指在建表時(shí)頻繁使用的表名或列名,下表對(duì)常用字段進(jìn)行建議性定義,列名稱數(shù)據(jù)類型說明CreatedDatedat(yī)etime紀(jì)錄創(chuàng)建日期,一般使用GETDATE()自動(dòng)生成ModifiedDat(yī)edatetime
紀(jì)錄最后修改日期,初次使用GETDATE()DeletedDatedat(yī)etime記錄刪除(標(biāo)記刪除)日期StartDatedatetime開始日期EndDate
datetime結(jié)束日期StartTimedatetime開始時(shí)間EndTimedat(yī)etime結(jié)束時(shí)間ID
int
使用ID代替Id或idParentIDint父IDStatusint狀態(tài)SQL編寫大小寫大寫T-SQL語言的所有關(guān)鍵字,謂詞和系統(tǒng)函數(shù)。變量名稱及游標(biāo)名稱使用Pascal樣式。數(shù)據(jù)類型定義使用所有小寫。
示例:DECLARE@LastNamenvarchar(32);存儲(chǔ)格式盡量采用Unicode數(shù)據(jù)存儲(chǔ)格式,提高可移植性和兼容性,實(shí)際應(yīng)用中盡量使用nchar、nvarchar、ntext代替char、varchar、text。類型選擇假如字符具有明確的長(zhǎng)度,使用nchar代替nvarchar;char代替varchar。在只有兩個(gè)也許數(shù)值時(shí),使用bit代替int或smallint。在SQLServer2023中,使用nvarchar(MAX)代替ntext;varchar(MAX)代替text;varbinary(MAX)代替image。在特殊的數(shù)據(jù)表結(jié)構(gòu)中可考慮xml數(shù)據(jù)類型,達(dá)成事半工倍的效果。默認(rèn)值在建立數(shù)據(jù)表時(shí),盡量使用默認(rèn)值代替NULL值。比如設(shè)立CreatedDate列默認(rèn)值為GETDATE()。在可行的情況下設(shè)立字段為不允許空。字段長(zhǎng)度始終指定字符數(shù)據(jù)類型的長(zhǎng)度,并保證允許用戶也許需要的最大字符數(shù),避免超過最大長(zhǎng)度時(shí)出現(xiàn)字符丟失現(xiàn)象。對(duì)于字符型數(shù)據(jù),建議采用2的n次方來定義數(shù)據(jù)長(zhǎng)度。示例:nvarchar(32)
varchar(64)使用“'”在T-SQL代碼中為字符常量使用單引號(hào),避免使用雙引號(hào)。語句縮進(jìn)一個(gè)嵌套代碼塊中的語句使用2個(gè)空格的縮進(jìn)。語句換行建議SQL代碼每行以關(guān)鍵字或“'”開頭。示例:SELECT[ShiftID]
,[Name]
,[StartTime]
,[EndTime]
,[ModifiedDate]FROM[AdventureWo(hù)rks].[HumanResources].[Shift]語句分割使用一個(gè)(而不是兩個(gè))空行分隔T-SQL代碼的邏輯塊。使用“*”盡量避免在任何代碼中使用“SELECT*”。表名別名表名別名要簡(jiǎn)短,但意義要盡量明確。通常使用大寫的表名作為別名,使用AS關(guān)鍵字指定表或字段的別名。類型轉(zhuǎn)換不要依賴任何隱式的數(shù)據(jù)類型轉(zhuǎn)換,不要假定T-SQL會(huì)進(jìn)行必要的轉(zhuǎn)換。例如,把數(shù)字變量賦予字符值。相反,在為變量賦值或比較值之前,應(yīng)使用適當(dāng)?shù)腃ONVERT函數(shù)使數(shù)據(jù)類型相匹配。數(shù)值比較不要將空的變量值直接與比較運(yùn)算符(符號(hào))比較。假如變量也許為空,應(yīng)使用ISNULL或ISNOTNULL進(jìn)行比較,或者使用ISNULL函數(shù)。排序決不要依賴SELECT語句會(huì)按任何特定順序返回行,除非在ORDERBY子句中指定了順序。通常,應(yīng)將ORDERBY子句與SELECT語句一起使用??深A(yù)知的順序(即使不是最方便的)比不可預(yù)知的順序強(qiáng),特別是在開發(fā)或調(diào)試過程中。在返回行的順序無關(guān)緊要的情況下,可以忽略ORDERBY,減少資源開銷。Unicode字符串在Unicode字符前面使用N前綴,避免引起數(shù)據(jù)的不一致。示例:--AssumesthedefaultcodepageisnotGreekCREATETABLE#t1(c1nchar(1))INSERT#t1VALUES(N'Ω')INSERT#t1VALUES('Ω')SELECT*FROM#t1輸出結(jié)果:c1
ΩOBEGIN...END塊在SQL代碼快中盡量使用BEGIN...END語句塊,提高代碼可閱讀性。TOP子句盡量使用TOP(變量)來減少SQL拼串現(xiàn)象。TRANSACTION編寫只要在例程中使用多個(gè)數(shù)據(jù)庫修改語句,涉及在一個(gè)循環(huán)中多次執(zhí)行一個(gè)語句,就應(yīng)考慮聲明顯式事務(wù)。實(shí)例:
BEGINTRANSACTIONTran_1;
UPDATE[HumanResources].[Employee]
SET[Title]=@Title
,[HireDat(yī)e]=@HireDate
,[CurrentFlag]=@CurrentFlag
WHERE[Employee(cuò)ID]=@EmployeeID;
IF@@ERROR>0
BEGIN
ROLLBACKTRANSACTIONTran_1;
END
COMMITTRANSACTIONTran_1;存儲(chǔ)過程在編寫存儲(chǔ)過程時(shí),使用PROCEDURE代替PROC簡(jiǎn)寫。示例:CREATEPROCEDURE[dbo].[存儲(chǔ)過程名字]代碼注釋代碼頭部
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 法律案例解析圖書出版行業(yè)跨境出海項(xiàng)目商業(yè)計(jì)劃書
- 民俗文化扶貧行業(yè)跨境出海項(xiàng)目商業(yè)計(jì)劃書
- 生物自然觀察社團(tuán)行業(yè)深度調(diào)研及發(fā)展項(xiàng)目商業(yè)計(jì)劃書
- 環(huán)保材料制品行業(yè)深度調(diào)研及發(fā)展項(xiàng)目商業(yè)計(jì)劃書
- 危險(xiǎn)廢物規(guī)范化省級(jí)評(píng)估指標(biāo)體系
- 強(qiáng)化科學(xué)教育與人文教育協(xié)同的策略及實(shí)施路徑
- 康養(yǎng)醫(yī)養(yǎng)中心建設(shè)項(xiàng)目可行性研究報(bào)告
- 加強(qiáng)建筑施工質(zhì)量管控實(shí)施方案
- 城市地下空間綜合開發(fā)利用的策略及實(shí)施路徑
- 數(shù)學(xué)思維培養(yǎng)夏令營(yíng)計(jì)劃
- 2025年高考政治搶押秘籍(江蘇專用)時(shí)政熱點(diǎn)04哪吒2(學(xué)生版+解析)
- 廣東省深圳市2025年中考模擬歷史試題四套附參考答案
- 粵語知識(shí)測(cè)試題及答案
- 2025年北京市東城區(qū)初三語文一模作文《根基》寫作指導(dǎo)+范文
- 2025年高考化學(xué)考試易錯(cuò)題易錯(cuò)類型18物質(zhì)的分離、提純與鑒別(7大易錯(cuò)點(diǎn))(學(xué)生版+解析)
- 內(nèi)蒙古榮信化工有限公司招聘筆試題庫2025
- 美容外科概論試題及答案
- 加工風(fēng)管合同樣本
- 2025-2030中國(guó)電動(dòng)自行車充電樁行業(yè)市場(chǎng)深度分析及發(fā)展前景與投資研究報(bào)告
- 本土資源在小學(xué)水墨畫教學(xué)中的實(shí)踐與運(yùn)用000
- 專升本心理學(xué)題庫+參考答案
評(píng)論
0/150
提交評(píng)論