---------------------------------------------------------------------- /*更新貨單編號 含禁用啓用全部外鍵*/ ---------------------------------------------------------------------- --得到禁用全部外鍵約束的語句 select 'ALTER TABLE [' + b.name + '] NOCHECK CONSTRAINT ' + a.name +';' as 禁用約束 from sysobjects a ,sysobjects b where a.xtype ='f' and a.parent_obj = b.id --得到啓用全部外鍵約束的語句 select 'ALTER TABLE [' + b.name + '] CHECK CONSTRAINT ' + a.name +';' as 啓用約束 from sysobjects a ,sysobjects b where a.xtype ='f' and a.parent_obj = b.id declare @ varchar(8000) set @ = '' select @ = @ + 'ALTER TABLE ' + b.name + ' NOCHECK CONSTRAINT ' + a.name + char(13) from sysobjects a ,sysobjects b where a.xtype = 'f' and a.parent_obj = b.id exec (@)
/*開始操做*/ DECLARE @OldManifestID varchar(10),@NewManifestID varchar(10) SET @OldManifestID='22186796' SET @NewManifestID='2186796' --修改付款 UPDATE dbo.tb_Pay SET ManifestID=@NewManifestID WHERE ManifestID=@OldManifestID --修改結帳 UPDATE dbo.tb_Checkout SET ManifestID=@NewManifestID WHERE ManifestID=@OldManifestID --修改提貨 UPDATE dbo.tb_Delivery SET ManifestID=@NewManifestID WHERE ManifestID=@OldManifestID --修改流程 UPDATE dbo.tb_ProcessLogs SET ManifestID=@NewManifestID WHERE ManifestID=@OldManifestID --修改收支 UPDATE dbo.tb_InExpen SET ManifestID=@NewManifestID WHERE ManifestID=@OldManifestID --修改貨單 UPDATE dbo.tb_Manifest SET ManifestID=@NewManifestID WHERE ManifestID=@OldManifestID /*結束操做*/ set @ = '' select @ = @ + 'ALTER TABLE ' + b.name + ' CHECK CONSTRAINT ' + a.name + char(13) from sysobjects a ,sysobjects b where a.xtype = 'f' and a.parent_obj = b.id exec (@)
--1、刪除全部表的外鍵約束 DECLARE c1 cursor for select 'alter table ['+ object_name(parent_obj) + '] drop constraint ['+name+']; ' from sysobjects where xtype = 'F' open c1 declare @c1 varchar(8000) fetch next from c1 into @c1 while(@@fetch_status=0) begin exec(@c1) fetch next from c1 into @c1 end close c1 deallocate c1 --2、刪除全部表 use suqifeng GO declare @sql varchar(8000) while (select count(*) from sysobjects where type='U')>0 begin SELECT @sql='drop table ' + name FROM sysobjects WHERE (type = 'U') ORDER BY 'drop table ' + name exec(@sql) end --刪除全部的存儲過程同 type = 'U'
SQL的主鍵和外鍵的做用: 外鍵取值規則:空值或參照的主鍵值。 (1)插入非空值時,若是主鍵表中沒有這個值,則不能插入。 (2)更新時,不能改成主鍵表中沒有的值。 (3)刪除主鍵表記錄時,你能夠在建外鍵時選定外鍵記錄一塊兒級聯刪除仍是拒絕刪除。 (4)更新主鍵記錄時,一樣有級聯更新和拒絕執行的選擇。 簡而言之,SQL的主鍵和外鍵就是起約束做用。 關係型數據庫中的一條記錄中有若干個屬性,若其中某一個屬性組(注意是組)能惟一標識一條記錄,該屬性組就能夠成爲一個主鍵。 好比: 學生表(學號,姓名,性別,班級) 其中每一個學生的學號是惟一的,學號就是一個主鍵; 課程表(課程編號,課程名,學分) 其中課程編號是惟一的,課程編號就是一個主鍵; 成績表(學號,課程號,成績) 成績表中單一一個屬性沒法惟一標識一條記錄,學號和課程號的組合才能夠惟一標識一條記錄,因此,學號和課程號的屬性組是一個主鍵。 成績表中的學號不是成績表的主鍵,但它和學生表中的學號相對應,而且學生表中的學號是學生表的主鍵,則稱成績表中的學號是學生表的外鍵;同理,成績表中的課程號是課程表的外鍵。 定義主鍵和外鍵主要是爲了維護關係數據庫的完整性,總結一下: 1、主鍵是能肯定一條記錄的惟一標識,好比,一條記錄包括身份正號,姓名,年齡。身份證號是惟一能肯定你這我的的,其餘均可能有重複,因此,身份證號是主鍵。 外鍵用於與另外一張表的關聯。是能肯定另外一張表記錄的字段,用於保持數據的一致性。好比,A表中的一個字段,是B表的主鍵,那他就能夠是A表的外鍵。 2、主鍵、外鍵和索引的區別 定義: 主鍵--惟一標識一條記錄,不能有重複的,不容許爲空 外鍵--表的外鍵是另外一表的主鍵, 外鍵能夠有重複的, 能夠是空值 索引--該字段沒有重複值,但能夠有一個空值 做用: 主鍵--用來保證數據完整性 外鍵--用來和其餘表創建聯繫用的 索引--是提升查詢排序的速度 個數: 主鍵--主鍵只能有一個 外鍵--一個表能夠有多個外鍵 索引--一個表能夠有多個惟一索引 建立SQL的主鍵和外鍵約束的方法: create table Student --建表格式:create table 自定義的表名 ( --字段名通常爲有必定意義的英文 StudentName nvarchar(15), -- 格式:字段名類型()括號裏面的是容許輸入的長度 StudentAge int, --int型的後面不須要接長度 StudentSex nvarchar(2) --最後一個字段後面不要逗號 ) --在建立表時就能夠對字段加上約束: create table Student ( StudentNo int PRIMARY KEY IDENTITY(1,1), --加主鍵約束,還有標識列屬性(二者構成實體完整性) StudentName nvarchar(15) not null, --加非空約束,不加"not null" 默認爲:能夠爲空 StudentSchool text(20) FOREIGN KEY REFERENCES SchoolTable(SchoolName), --加外鍵約束,格式:FOREIGN KEY REFERENCES 關聯的表名(字段名) StudentAge int DEFAULT ((0)), --加默認值約束 StudentSex nvarchar(2) CHECK(StudentSex=N'男' or StudentSex=N'女') --加檢查約束,格式:check (條件表達式) ) --若是在表建立好了之後再加約束,則格式分別爲: -- 主鍵: alter table 表名 add constraint PK_字段名--"PK"爲主鍵的縮寫,字段名爲要在其上建立主鍵的字段名,'PK_字段名'就爲約束名 primary key (字段名) --字段名同上 --惟一約束: alter table 表名 add constraint UQ_字段名 unique (字段名) --外鍵約束: alter table 表名 add constraint FK_字段名--"FK"爲外鍵的縮寫 foreign key (字段名) references 關聯的表名(關聯的字段名) --注意'關聯的表名'和'關聯的字段名' alter table 表A add constraint FK_B foreign key (ticket_no) references 表B(ticket_no) alter table 表A add constraint FK_C foreign key (person_no) references 表C(person_no) alter table 成績表 add constraint FK_StudentNo foreign key (StudentNo) references Student (StudentNo) ON UPDATE CASCADE ON DELETE CASCADE 級聯更新,級聯刪除,這樣在刪除主表Student時,成績表中該學生的全部成績都會刪除。 --檢查約束: alter table 表名 add constraint CK_字段名 check (條件表達式) --條件表達式中的條件用關係運算符鏈接 --默認值約束: alter table 表名 add constraint DF_字段名 default '默認值' for 字段名--其中的'默認值'爲你想要默認的值,注意'for' --刪除建立的約束: alter table 表名 drop constraint 約束名--約束名爲你前面建立的如:PK_字段這樣的約束名 --注意:若是約束是在建立表的時候建立的,則不能用命令刪除 --只能在'企業管理器'裏面刪除 -- 獲取SqlServer中表結構 SELECT syscolumns.name,systypes.name,syscolumns.isnullable, syscolumns.length FROM syscolumns,systypes WHERE syscolumns.xusertype = systypes.xusertype AND syscolumns.id = OBJECT_ID('Student') -- 單獨查詢表遞增字段 SELECT [name] FROM syscolumns WHERE id = OBJECT_ID(N'Student') AND COLUMNPROPERTY(id,name,'IsIdentity')=1 -- 獲取表主外鍵約束 EXEC sp_helpconstraint 'StuResults' -- 查詢表主鍵外鍵信息 SELECT sysobjects.id objectId,OBJECT_NAME(sysobjects.parent_obj) tableName, sysobjects.name constraintName, sysobjects.xtype AS constraintType, syscolumns.name AS columnName FROM sysobjects INNER JOIN sysconstraints ON sysobjects.xtype in('C', 'F', 'PK', 'UQ', 'D') AND sysobjects.id = sysconstraints.constid LEFT OUTER JOIN syscolumns ON sysconstraints.id = syscolumns.id WHERE OBJECT_NAME(sysobjects.parent_obj)='StuResults'