⑴ sql server 刪除全部外鍵
--查出外鍵
select name
from sys.foreign_key_columns f join sys.objects o on f.constraint_object_id=o.object_id
where f.parent_object_id=object_id('表名')
--刪除外鍵
alter table 表名 drop constraint 外簡名
⑵ 如何刪除sql中帶外鍵的表數據
為什麼一定要一句話呢?一個sql語句不能同時刪除兩張表,除非通過外鍵級聯刪除或者觸發器,最正常的做法當然是寫成2個sql語句,然後用一個trans來保證數據一致性,如果非要用一個sql語句,可以有一個變通方法,寫一側存儲過程,刪除兩張表,然後寫的一句sql是執行這個存儲過程
⑶ SQL中怎樣刪除表的主外鍵
--刪除主鍵
alter table Stu_PkFk_S drop constraint PK_S
刪除SQL SERVER外鍵
alter table Stu_PkFk_Sc drop constraint FK_s
關系型資料庫中的一條記錄中有若干個屬性,若其中某一個屬性組(注意是組)能唯一標識一條記錄,該屬性組就可以成為一個主鍵
比如
學生表(學號,姓名,性別,班級)
其中每個學生的學號是唯一的,學號就是一個主鍵
課程表(課程編號,課程名,學分)
其中課程編號是唯一的,課程編號就是一個主鍵
成績表(學號,課程號,成績)
成績表中單一一個屬性無法唯一標識一條記錄,學號和課程號的組合才可以唯一標識一條記錄,所以 學號和課程號的屬性組是一個主鍵
成績表中的學號不是成績表的主鍵,但它和學生表中的學號相對應,並且學生表中的學號是學生表的主鍵,則稱成績表中的學號是學生表的外鍵
同理 成績表中的課程號是課程表的外鍵
⑷ SQL刪除資料庫中的所有數據
Sql Server中清空所有數據表中的記錄
清空所有數據表中的記錄:
復制代碼 代碼如下:
exec sp_msforeachtable @Command1 ='truncate table ?'
刪除所有數據表:
復制代碼 代碼如下:
exec sp_msforeachtable 'delete N''?'''
清空SQL Server資料庫中所有表數據的方法(有約束的情況)
其實刪除資料庫中數據的方法並不復雜,為什麼我還要多此一舉呢,一是我這里介紹的是刪除資料庫的所有數據,因為數據之間可能形成相互約束關系,刪除操作可能陷入死循環,二是這里使用了微軟未正式公開的sp_MSForEachTable存儲過程。
也許很多讀者朋友都經歷過這樣的事情:要在開發資料庫基礎上清理一個空庫,但由於對資料庫結構缺乏整體了解,在刪除一個表的記錄時,刪除不了,因為可能有外鍵約束,一個常見的資料庫結構是一個主表,一個子表,這種情況下一般都得先刪除子表記錄,再刪除主表記錄。
說道刪除數據記錄,往往馬上會想到的是delete和truncate語句,但在遇到在兩個或多個表之間存在約束的話,這兩個語句可能都會失效,而且最要命的是這兩個命令都只能一次操作一個表。那麼真正遇到要刪除SQL Server資料庫中所有記錄時,該怎麼辦呢?有兩個選擇:
1.按照先後順序逐個刪除,這個方法在表非常多的情況下顯得很不現實,即便是表數量不多,但約束比較多時,你還是要花費大量的時間和精力去研究其間的約束關系,然後找出先刪哪個表,再刪哪個表,最後又刪哪個表。
2.禁用所有約束,刪除所有數據,最後再啟用約束,這樣就不用花時間和精力去研究什麼約束了,只需要編寫一個簡單的存儲過程就可以自動完成這個任務。
復制代碼 代碼如下:
CREATE PROCEDURE sp_DeleteAllData
AS
EXEC sp_MSForEachTable 'ALTER TABLE ? NOCHECK CONSTRAINT ALL'
EXEC sp_MSForEachTable 'ALTER TABLE ? DISABLE TRIGGER ALL'
EXEC sp_MSForEachTable 'DELETE FROM ?'
EXEC sp_MSForEachTable 'ALTER TABLE ? CHECK CONSTRAINT ALL'
EXEC sp_MSForEachTable 'ALTER TABLE ? ENABLE TRIGGER ALL'
EXEC sp_MSFOREACHTABLE 'SELECT * FROM ?'
GO
從這兩個選擇中不難看出第二個選擇是最簡單有效的了,那麼在使用第二個選擇時,具體該怎麼實施呢?
首先得編寫代碼循環檢查所有的表,這里我推薦一個存儲過程sp_MSForEachTable,因為在微軟的官方文檔中沒有對這個存儲過程有描述,很多開發人員也許都還未曾聽說,所以你在互聯網上搜索得到的解決辦法大多很復雜,也許有的人會認為,既然沒有官方文檔,這個存儲過程可能會不穩定,打心理上會排斥它,但事實並非如此。下面來先看一個完整的腳本:
這個腳本創建了一個命名為sp_DeleteAllData的存儲過程,前面兩行語句分別禁用約束和觸發器,第三條語句才是真正地刪除所有數據,接下里的語句分別還原約束和觸發器,最後一條語句是顯示每個表中的記錄,當然這條語句也可以不要,我只是想確認一下是否清空了所有表而已。
你可以在任何資料庫上運行這個存儲過程,當然不要在生成資料庫上運行,可別怪我沒告訴你!不管怎樣,還是先備份一下資料庫,使用備份資料庫還原,然後再運行該存儲過程,呵呵,即使是一個大型資料庫,也要不多長時間,你的資料庫就成一個空庫了
第三種方法:TRUNCATE TABLE
在sql server資料庫中快速刪除記錄,清空表若要刪除表中的所有行,則 TRUNCATE TABLE 語句是一種快速、無日誌記錄的方法。TRUNCATE TABLE 與不含有 WHERE 子句的 DELETE 語句在功能上相同。但是,TRUNCATE TABLE 速度更快,並且使用更少的系統資源和事務日誌資源。
與 DELETE 語句相比,TRUNCATE TABLE 具有以下優點:
所用的事務日誌空間較少。
DELETE 語句每次刪除一行,並在事務日誌中為所刪除的每行記錄一項。TRUNCATE TABLE 通過釋放用於存儲表數據的數據頁來刪除數據,並且在事務日誌中只記錄頁釋放。
使用的鎖通常較少。
當使用行鎖執行 DELETE 語句時,將鎖定表中各行以便刪除。TRUNCATE TABLE 始終鎖定表和頁,而不是鎖定各行。
如無例外,在表中不會留有任何頁。
執行 DELETE 語句後,表仍會包含空頁。例如,必須至少使用一個排他 (LCK_M_X) 表鎖,才能釋放堆中的空表。如果執行刪除操作時沒有使用表鎖,表(堆)中將包含許多空頁。對於索引,刪除操作會留下一些空頁,盡管這些頁會通過後台清除進程迅速釋放。
與 DELETE 語句相同,使用 TRUNCATE TABLE 清空的表的定義與其索引和其他關聯對象一起保留在資料庫中。
⑸ sql server怎樣刪除外鍵約束
1.首先,我們使用SQLSERVER2008打開需要刪除外鍵約束的表,點擊左側的「dbo」通道項,選擇「setclick」。
注意事項:
可以雙擊鍵約束來添加外鍵約束,它有四個不同的選項:CASCADE、SETNULL、NOACTION、restricted。
1.級聯:刪除或更新父表中相應的行,並自動刪除或更新表中匹配的行。[在刪除CANSCADE和更新CANSCADE都支持InnoDB。
2.SETNULL:刪除或更新父表中對應的行,並將子表中的外鍵列設置為空。注意,這些外鍵列沒有設置為NOTNULL。InnoDB支持刪除集空值和更新集空值。
3.無操作:InnoDB拒絕刪除或更新父表。
4.限制:拒絕刪除或更新父表。
⑹ sql server怎麼刪除外鍵
x先找出約束名字
然後刪山正納除它
我給個例子
--測試環境
--主表
create table test1(id int primary key not null,value int)
insert test1 select 1,2
go
--從表
create table test2(id int references test1(id),value int)
go
--第一步:找出test2表上的外鍵約束名字
--2000
exec sp_helpconstraint 'test2'
--可以在constraint_name 屬性中逗沒找到外鍵約束名字
--2005
select name
from sys.foreign_key_columns f join sys.objects o on f.constraint_object_id=o.object_id
where f.parent_object_id=object_id('test2')
/*
name
---------------------------------
FK__test2__id__08EA5793*/
--第二步:清胡刪除外鍵約束
alter table test2 drop constraint FK__test2__id__08EA5793
--第三步:檢查表上是否還有外鍵約束
--只要使用第一步裡面的查找語句即可
⑺ 求SQL語句,在資料庫中刪除所有表的外鍵關系,謝謝。但是個別幾個表的外鍵關系我手動刪除了。
declare @nn varchar(50),@mm varchar(50)
declare cur_name cursor for
select name from sysobjects where type ='螞鬧手U' --找出資料庫中所有表名稱
open cur_name
fetch cur_name into @nn
while @@fetch_status=0
begin
declare cur_name1 cursor for
select name from sysobjects where type ='PK' --找悶嫌出資料庫彎此中所有外鍵名稱
open cur_name1
fetch cur_name1 into @mm
while @@fetch_status=0
begin
--檢查表@nn是否存在@mm外鍵
if exists(select *from sysindexes where object_id=object_id(@nn) and name=@mm)
exec('alter 『+@nn +』 drop constrain『+@mm)
fetch cur_name into @mm
end
close cur_name1
deallocatecur_name1
fetch cur_name into @nn
end
close cur_name
deallocate cur_name
⑻ sql 刪除帶外鍵約束的表的語句是什麼
1、創建主鍵表,test_class,並建立class_id欄位為主鍵;
create table test_class(class_id number, class_name varchar2(20));
-- Create/Recreate indexes
alter table TEST_CLASS
add constraint P_CLASS_ID primary key (CLASS_ID)
using index
tablespace USERS
pctfree 10
initrans 2
maxtrans 255;
⑼ mysql資料庫怎麼刪除一個表的外鍵
mysql刪除外鍵語法:
altertabless_accesscodedropforeignkey外鍵約束名稱;
外鍵定義:
如果公共關鍵字在一個關系中是主關鍵字,那麼這個公共關鍵字被稱為另一個關系的外鍵。由此可見,外鍵表示了兩個關系之間的相關聯系。以另一個關系的外鍵作主關鍵字的表被稱為主表,具有此外鍵的表被稱為主表的從表。外鍵又稱作外關鍵字。
作用:
保持數據一致性,完整性,主要目的是控制存儲在外鍵表中的數據。 使兩張表形成關聯,外鍵只能引用外表中的列的值或使用空值。
⑽ sql server怎樣刪除外鍵約束
用這個跟:alter table 表名稱 drop constraint 外鍵的名稱
使用如下SQL語句查詢出表中外鍵約束名稱:
1 select name 2 from sys.foreign_key_columns f join sys.objects o on f.constraint_object_id=o.object_id 3 where f.parent_object_id=object_id('表名')
執行如下SQL語句刪除鏈返即可。
1 alter table 表名 drop constraint 外鍵約束名
(10)sql清空數據外鍵擴展閱讀:
注族手意事項
鍵約束可雙擊關系線添加兆喚嫌外鍵約束,外鍵約束有四種不同的選項:CASCADE, SET NULL, NO ACTION, RESTRICT。
1、CASCADE : 從父表中刪除或更新對應的行,同時自動的刪除或更新自表中匹配的行。[ON DELETE CANSCADE和ON UPDATE CANSCADE都被InnoDB所支持。
2、SET NULL: 從父表中刪除或更新對應的行,同時將子表中的外鍵列設為空。[注意,這些在外鍵列沒有被設為NOT NULL時才有效。ON DELETE SET NULL和ON UPDATE SET SET NULL都被InnoDB所支持。
3、NO ACTION: InnoDB拒絕刪除或者更新父表。
4、RESTRICT: 拒絕刪除或者更新父表。