SQL Server約束方式代碼_第1頁
SQL Server約束方式代碼_第2頁
SQL Server約束方式代碼_第3頁
SQL Server約束方式代碼_第4頁
SQL Server約束方式代碼_第5頁
已閱讀5頁,還剩6頁未讀, 繼續(xù)免費閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)

文檔簡介

在表中添加約束,基本常用的有兩種類型,一個是創(chuàng)建表時同時添加約束,另一個是創(chuàng)建好表通過修改表添加約束,在這里是創(chuàng)建表時同時添加約束,但是有兩種不同的用寫法。在這里列舉出一些創(chuàng)建約束的形式,共參考(均在SQLServer2005中編譯通過):createdatabasestuDBgousestuDBgo 1.1先創(chuàng)建表在創(chuàng)建表,然后通過修改表在創(chuàng)建約束(理論課中的示例)--先創(chuàng)建表CREATETABLEstuInfo/*-創(chuàng)建學(xué)員信息表-*/(stuNameVARCHAR(20)NOTNULL,--學(xué)員姓名,非空(必填)stuNoCHAR(6)NOTNULL,--學(xué)號,非空(必填)stuAgeINTNOTNULL,—年齡,INT類型不用指定大小,默認為個字節(jié)stuIDNUMERIC(18,0), --身份證號,NUMERIC(18,0)代表位數(shù)字,小數(shù)位數(shù)為stuSeatSMALLINTIDENTITY(1,1), --座位號,自動編號(標識列),從開始遞增stuAddressTEXT--住址,允許為空,即可選輸入GOCREATE(ExamNoTABLEstuMarksCHAR(7)NOTNULL,-fy.口--考號stuNoCHAR(6)NOTNULL,--學(xué)號writtenExamINTNOTNULL,--筆試成績GO--然后健約束 添加主鍵約束(stuNo作為主鍵)ALTERTABLEstuInfoADDCONSTRAINTPK_stuNoPRIMARYKEY(stuNo)---添加唯一約束(身份證號唯一,因為每人的身份證號全國唯一)ALTERTABLEstuInfoADDCONSTRAINTUQ_stuIDUNIQUE(stuID)---添加默認約束(如果地址不填,默認為“地址不詳”)ALTERTABLEstuInfoADDCONSTRAINTDF_stuAddressDEFAULT('地址不詳')FORstuAddress-一添加檢查check約束,要求年齡只能在一歲之間ALTERTABLEstuInfoADDCONSTRAINTCK_stuAgeCHECK(stuAgeBETWEEN15AND40)--添加外鍵約束(主表stuInfo和從表stuMarks建立關(guān)系,關(guān)聯(lián)字段為stuNo)ALTERTABLEstuMarksADDCONSTRAINTFK_stuNoFOREIGNKEY(stuNo)REFERENCESstuInfo(stuNo)GO 1.2先創(chuàng)建表在創(chuàng)建表,然后通過修改表在創(chuàng)建約束(項目實戰(zhàn)中的的示例)droptablestuMarksdroptablestuInfogo--先創(chuàng)建表CREATETABLEstuInfo/*-創(chuàng)建學(xué)員信息表-*/(stuNameVARCHAR(20)NOTNULL,--學(xué)員姓名,非空(必填)stuNoCHAR(6)NOTNULL,--學(xué)號,非空(必填)stuAgeINTNOTNULL,—年齡,INT類型不用指定大小,默認為個字節(jié)stuIDNUMERIC(18,0), --身份證號,NUMERIC(18,0)代表位數(shù)字,小數(shù)位數(shù)為stuSeatSMALLINTIDENTITY(1,1), --座位號,自動編號(標識列),從開始遞增stuAddressTEXT--住址,允許為空,即可選輸入)GOCREATE(ExamNoTABLEstuMarksCHAR(7)NOTNULL,-fy.口--考號stuNoCHAR(6)NOTNULL,--學(xué)號writtenExamINTNOTNULL,--筆試成績LabExamINTNOTNULL --機試成績)GO--然后健約束,注意:與前面的示例的區(qū)別是用“,”號隔開ALTERTABLEstuInfoADDCONSTRAINTPK_stuNoPRIMARYKEY(stuNo)---添加唯一約束(身份證號唯一,因為每人的身份證號全國唯一),CONSTRAINTUQ_stuIDUNIQUE(stuID)---添加默認約束(如果地址不填,默認為“地址不詳”),CONSTRAINTDF_stuAddressDEFAULT('地址不詳')FORstuAddress一-添加檢查check約束,要求年齡只能在一歲之間,CONSTRAINTCK_stuAgeCHECK(stuAgeBETWEEN15AND40)--添加外鍵約束(主表stuInfo和從表stuMarks建立關(guān)系,關(guān)聯(lián)字段為stuNo),CONSTRAINTFK_stuNoFOREIGNKEY(stuNo)REFERENCESstuInfo(stuNo)GO 2.1創(chuàng)建表時同時添加約束 droptablestuMarksdroptablestuInfogoCREATETABLEstuInfo/*-創(chuàng)建學(xué)員信息表-*/(stuNameVARCHAR(20)NOTNULL, --學(xué)員姓名,非空(必填)stuNoCHAR(6)primarykey, --學(xué)號,主鍵stuAgeINTNOTNULLcheck(stuAgebetween15and40), --年齡,檢查約束stuIDNUMERIC(18,0)unique, --身份證號,NUMERIC(18,0)代表位數(shù)字,小數(shù)位數(shù)為,該列唯一約束stuSeatSMALLINTIDENTITY(1,1), --座位號,自動編號(標識列),從開始遞增stuAddressTEXTdefault'地址不詳'--住址,允許為空,即可選輸入,默認”地址不詳“GOCREATETABLEstuMarks(ExamNoCHAR(7)primarykey,--考號,主鍵stuNoCHAR(6)NOTNULLforeignkeyreferencesstuInfo(stuNo), --學(xué)號,外鍵writtenExamINTNOTNULL,--筆試成績GO 2.2創(chuàng)建表時同時添加約束,另一個版本 droptablestuMarksdroptablestuInfogoCREATETABLEstuInfo/*-創(chuàng)建學(xué)員信息表-*/(stuNameVARCHAR(20)NOTNULL,--學(xué)員姓名,非空(必填)stuNoCHAR(6),CONSTRAINTpk_stuNoprimarykey(stuNo),--學(xué)號,主鍵stuAgeINTNOTNULL, --年齡,constraintck_stuAgecheck(stuAgebetween15and40),--檢查約束stuIDNUMERIC(18,0), --身份證號,NUMERIC(18,0)代表位數(shù)字,小數(shù)位數(shù)為,該列唯一約束constraintuq_stuIdunique(stuID),stuSeatSMALLINTIDENTITY(1,1), --座位號,自動編號(標識列),從開始遞增stuAddressTEXT, --住址,允許為空,即可選輸入)GOCREATETABLEstuMarks(ExamNoCHAR(7)primarykey,--考號,主鍵stuNoCHAR(6)NOTNULL, --學(xué)號,外鍵constraintfk_stuNoforeignkey(stuNo)referencesstuInfo(stuNo),writtenExamINTNOTNULL,--筆試成績LabExamINTNOTNULL --機試成績)GO--再來droptablestuMarksdroptablestuInfogoCREATETABLEstuInfo/*-創(chuàng)建學(xué)員信息表-*/(stuNameVARCHAR(20)NOTNULL, --學(xué)員姓名,非空(必填)stuNoCHAR(6),primarykey(stuNo), -學(xué)號,主鍵stuAgeINTNOTNULL,--年齡,check(stuAgebetween15and40),--檢查約束stuIDNUMERIC(18,0), --身份證號,NUMERIC(18,0)代表位數(shù)字,小數(shù)位數(shù)為,該列唯一約束unique(stuID),stuSeatSMALLINTIDENTITY(1,1), --座位號,自動編號(標識列),從開始遞增stuAddressTEXT, --住址,允許為空,即可選輸入)GOCREATETABLEstuMarks(ExamNoCHAR(7)primarykey,--考號,主鍵stuNoCHAR(6)NOTNULL, --學(xué)號,外鍵foreignkey(stuNo)referencesstuInfo(stuNo),writtenExamINTNOTNULL,--筆試成績GO--添加復(fù)合主鍵droptablestuMarksdroptablestuInfogoCREATETABLEstuInfo/*-創(chuàng)建學(xué)員信息表-*/(stuNameVARCHAR(20)NOTNULL,--學(xué)員姓名,非空(必填)classNameCHAR(6)NOTNULL,--班級名稱,非空(必填)stuAgeINTNOTNULL,—年齡,INT類型不用指定大小,默認為個字節(jié))GO--然后健約束,注意:這里是復(fù)合主鍵ALTERTABLEstuInfoADDCONSTRAINTPK_stuNoPRIMARYKEY(className,stuName)--ORdroptablestuInfogo--先創(chuàng)建表CREATETABLEstuInfo/*-創(chuàng)建學(xué)員信息表-*/(stuNameVARCHAR(20)NOTNULL, --學(xué)員姓名,非空(必填)classNameCHAR(6)NOTNULL, --班級名稱,非空(必填)CONSTRAINTPK_stuNoPRIMARYKEY(className,stuName),--復(fù)合主鍵stuAgeINTNOTNULL,—年齡,INT類型不用指定大小,默認為個

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論