當前位置:首頁 » 數據倉庫 » pkfk資料庫
擴展閱讀
webinf下怎麼引入js 2023-08-31 21:54:13
堡壘機怎麼打開web 2023-08-31 21:54:11

pkfk資料庫

發布時間: 2022-07-05 10:01:02

如何刪除資料庫中所有外鍵關系

如何刪除資料庫中所有外鍵關系
--刪除主鍵
alter table Stu_PkFk_S drop constraint PK_S

刪除sql SERVER外鍵
alter table Stu_PkFk_Sc drop constraint FK_s

關系型資料庫中的一條記錄中有若干個屬性,若其中某一個屬性組(注意是組)能唯一標識一條記錄,該屬性組就可以成為一個主鍵
比如
學生表(學號,姓名,性別,班級)
其中每個學生的學號是唯一的,學號就是一個主鍵
課程表(課程編號,課程名,學分)
其中課程編號是唯一的,課程編號就是一個主鍵
成績表(學號,課程號,成績)
成績表中單一一個屬性無法唯一標識一條記錄,學號和課程號的組合才可以唯一標識一條記錄,所以 學號和課程號的屬性組是一個主鍵

⑵ sql server為什麼要設置主鍵

一、主鍵定義

資料庫主鍵是指表中一個列或者列的組合,其值能夠唯一的標識表中的每一個行。這樣的一列或者多列成為表的主鍵,通過它可以強製表的實體完整性。當創建或者更改表時可以通過定義PRIMARY KEY約束來創建主鍵,一個表只能有一個主鍵約束,而且主鍵約束中的列不能是空值,由於主鍵約束確保唯一數據,所一經常來定義標識列。


二、主鍵的作用

1、 主鍵是用於唯一標識資料庫表中一行數據的。

2、 作為一個可以被外鍵有效引用的對象。


三、主鍵的設計原則

1、 主鍵應當是對用戶沒有意義的,比如說用戶登陸一個系統的時候的登錄id;而這種情況就不可能了:「學生表」需要支持這樣的需求「學生注銷後,可以重新激活自己的信息,而且還要保持自己的號碼跟原來的一直」,這樣的話主鍵就不能滿足要求了。

2、 唯一性。

3、 非空性:主鍵的值是不可重復的,也不可以為空。

4、盡量不要更新主鍵。實際上,因為主鍵除了惟一地標識一行之外,再沒有其他的用途了,所以也就沒有理由去對它更新。如果主鍵需要更新,則說明主鍵應對用戶無意義的原則被違反了。注意:這項原則對於那些經常需要在數據轉換或多資料庫合並時進行數據整理的數據並不適用。

5、主鍵不應包含動態變化的數據,如時間戳、創建時間列、修改時間列等。

6、主鍵應當有計算機自動生成。如果由人來對主鍵的創建進行干預,就會使它帶有除了惟一標識一行以外的意義。一旦越過這個界限,就可能產生認為修改主鍵的動機,這樣,這種系統用來鏈接記錄行、管理記錄行的關鍵手段就會落入不了解資料庫設計的人的手中。


四、創建主鍵

--在創建表時就可以對欄位加上約束:
createtableStudent
(
(1,1),--加主鍵約束,還有標識列屬性(兩者構成實體完整性)
StudentNamenvarchar(15)notnull,--加非空約束,不加"notnull"默認為:可以為空
StudentSchooltext(20)(SchoolName),--加外鍵約束,格式:FOREIGNKEYREFERENCES關聯的表名(欄位名)
StudentAgeintDEFAULT((0)),--加默認值約束
StudentSexnvarchar(2)CHECK(StudentSex=N'男'orStudentSex=N'女')--加檢查約束,格式:check(條件表達式)
)



五、測試添加刪除主鍵

--刪除主鍵
altertableStu_PkFk_SdropconstraintPK_S
go
--增加主鍵
altertableStu_PkFk_SaddconstraintPK_Sprimarykey(sno)
go

⑶ 如何刪除資料庫中所有數據

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語句,將表spkfk中的欄位spid全部置為空,

update spkfk set spid=right('00000000'+
convert(varchar,row_number() over(order by id))

,8)

id為唯一的排序欄位

⑸ 如何在pb中刪除sql表的外鍵

--刪除主鍵
alter table Stu_PkFk_S drop constraint PK_S

刪除SQL SERVER外鍵
alter table Stu_PkFk_Sc drop constraint FK_s

關系型資料庫中的一條記錄中有若干個屬性,若其中某一個屬性組(注意是組)能唯一標識一條記錄,該屬性組就可以成為一個主鍵
比如
學生表(學號,姓名,性別,班級)
其中每個學生的學號是唯一的,學號就是一個主鍵
課程表(課程編號,課程名,學分)
其中課程編號是唯一的,課程編號就是一個主鍵
成績表(學號,課程號,成績)
成績表中單一一個屬性無法唯一標識一條記錄,學號和課程號的組合才可以唯一標識一條記錄,所以 學號和課程號的屬性組是一個主鍵

成績表中的學號不是成績表的主鍵,但它和學生表中的學號相對應,並且學生表中的學號是學生表的主鍵,則稱成績表中的學號是學生表的外鍵

同理 成績表中的課程號是課程表的外鍵

⑹ 在SQL中PK,FK是什麼意思

SQL中PK是指主鍵,FK是指外鍵.

一、主鍵與外鍵
1.主鍵是用來唯一地標識一行數據。主鍵列必須包含唯一的值,且不能包含空值(null)。
2.主鍵可以建立在每張二維表中單列或者多列上。
3.一張二維表上的外鍵可以引用另一張二維表上對應的主鍵。
主鍵會有鑰匙標識,如下圖中紅色圓圈內所示,外鍵沒有該標識:

拓展資料:
下面的 SQL 在 "Persons" 表創建時在 "Id_P" 列創建 PK(主鍵) 約束:
MySQL:
CREATE TABLE Persons
(
Id_P int NOT NULL,
LastName varchar(255) NOT NULL,
FirstName varchar(255),
Address varchar(255),
City varchar(255),PRIMARY KEY (Id_P))

⑺ postgreSQL 備份庫

cd到postgresql/bin目錄下:

備份資料庫:
pg_mp -h localhost -U greenerp greenerp > greenerp_140224.bak

恢復資料庫:
psql -h localhost -U greenerp -d greenerp < greenerp_140311.bak

⑻ 資料庫 視圖中<pk,fk>是什麼意思

SQL中PK,FK意思:
--主鍵
constraint PK_欄位 primary key(欄位),

--唯一約束
constraint UK_欄位 unique key(欄位),

--默認約束
constrint DF_欄位 default('默認值') for 欄位,

--檢查約束
constraint CK_欄位 check(約束。如:len(欄位)>1),

--主外鍵關系
constraint FK_主表_從表 foreign(外鍵欄位) references 主表(主表主鍵欄位)

⑼ 在SQL中如何創建外鍵約束

可以用創建關系圖的方式進行約束,步驟如下
企業管理器中打開資料庫,新建關系圖,選出自己所要的幾張表,然後將對應的外鍵用滑鼠連接到另一張表的主鍵上就行了
ps
環境
sql2000

⑽ mysql workbench資料庫建表的pknn是什麼意思

方法一:1、首先我們使用MySQL提供的命令行界面來導入資料庫,確保自己的電腦中安裝了MySQL資料庫,我們可以通過命令行來確認是否安裝了MySQL資料庫,當然,第一步是打開Mysql的資料庫服務,我們使用命令行來打開2、啟動MySQL後,我們找到需要用