當前位置:首頁 » 操作系統 » 資料庫添加外鍵

資料庫添加外鍵

發布時間: 2023-02-24 03:00:41

A. 資料庫外鍵怎麼設置

sql 資料庫建表時怎麼設置外鍵,
1> -- 創建測試主表. ID 是主鍵.

2> CREATE TABLE test_main (

3> id INT,

4> value VARCHAR(10),

5> PRIMARY KEY(id)

6> );

7> go

-- 建表時設置外鍵

1> CREATE TABLE test_sub (

2> id INT,

3> main_id INT,

4> value VARCHAR(10),

5> PRIMARY KEY(id),

6> FOREIGN KEY (main_id) REFERENCES test_main

7> );

8> go
sql怎麼設置外鍵
可以在創建表的時候創建,也可以在創建表之後創建。

創建表時創建:

create table student

(id int primary key,

name char(4),

dept char(9)

sex char(4))

create table grade

(id int ,

grade int

constraint id_fk foreign key (id) references student (id)

)

或創建了兩表之後再建

alter table grade

add constraint id_fk foreign key (id) references student (id)

呵呵,希望能幫助你。
sql server中圖形界面如何設置外鍵
在那個屬性上右鍵 有約束 自己添加就OK了
mysql怎麼設置外鍵?
ALTER TABLE b ADD CONSTRAINT c FOREIGN KEY(c) REFERENCES a(c) ON DELETE CASCADE ON UPDATE CASCADE; 哎呀。。好像寫反了。我寫的是把表B的c設置為外鍵了。。你改一下吧。
如何在資料庫的建立表的時候設置表的外鍵
1> -- 創建測試主表. ID 是主鍵.

2> CREATE TABLE test_main (

3> id INT,

4> value VARCHAR(10),

5> PRIMARY KEY(id)

6> );

7> go

-- 建表時設置外鍵

1> CREATE TABLE test_sub (

2> id INT,

3> main_id INT,

4> value VARCHAR(10),

5> PRIMARY KEY(id),

6> FOREIGN KEY (main_id) REFERENCES test_main

7> );

8> go
sql server 2008 怎麼設置外鍵
建外鍵的前提是此外鍵必須是另外一個表的主鍵。建外鍵的步驟: 第一步打開要建外鍵表的設計器,右擊選擇「關系」。然後彈出「外鍵關系」窗體,我們選擇「添加」,然後點擊「表和列規范」後面的小按鈕,就會彈出另外一個窗體讓我們選擇主鍵表和列,選好之後點擊確定。然後我們INSERT和UPDATE規范,在更新規則和刪除規則有四個選項,分別是「不執行任何操作」、「級聯」、「設置為NULL」、「設置默認值」。默認的不執行任何操作。如果是「不執行任何操作」,當我們刪除或更新主鍵表的數據時,會告訴用戶不能執行刪除或更新該操作。「級聯」的意思是當我們刪除或更新主鍵表的數據時,會刪除或更新外鍵表中所涉及的相關數據的所有行。 「設置Null」的意思是當我們刪除或更新主鍵表的數據時,外鍵表中的外鍵列的值會設為Null,但前提是該列允許為空。 「設置默認值」的意思是如果我們將外鍵列定義了默認值,當我們刪除或更新主鍵表的數據時,外鍵表中的外鍵列的值設為定義的默認值。 當然我們可以用代碼創建,當我們在創建資料庫表T——Card時只要加上一句話就OK啦,「Foreign key (studentNo) references T_Student(studentNo)"。如果我們已經創建了改表,那如何用代碼實現了,這也很簡單也就一句話「 add constraint CMPKey(外鍵名) foreign key(studentNo) references T_Student(studentNo)」。
sql中怎樣創建外鍵約束
在創建表之後,添加外鍵約束:

alter table yuangong add constraint fk foreign key (部門罰) references bumen(部門號)

或者在創建表的時候添加外鍵

foreign key (部門號) references bumen(部門號)放在最後,用","與列分隔
資料庫中,一對多的時候外鍵設置在多的那張表嗎?如果一對一的時候,外鍵應該設置在哪裡?多對多的時候,
首先,外鍵引用的那個列在主表中必須是主鍵列或者唯一列。

所以1:n的肯定把外鍵建立在n的那張表上。

1:1,一般要看誰是主表,誰是附屬表,外鍵當然建立在附屬表中。

n:m的情況,需要建立一個關系表,兩個原表和其關系分別是1:n,1

:m
資料庫語句怎麼加外鍵
1,創建表的時候添加:foreign key (你的外鍵) references (表名)(欄位名);

2,創建好之後修改:

alter table dbo.mh_User

add constraint FK_mh_User_..._id foreign key (你的外鍵) references (表名)(欄位名);
Sql server怎樣創建主外鍵關系
在要設置關系的外鍵表中,右擊關系→添加→在表和列規范中選擇關聯的主表再選擇外鍵表與其關聯的欄位

B. 資料庫外鍵約束

資料庫外鍵約束:這個是實現表與表之間的約束,從表的欄位值必須在主表中。存在外鍵約束畢竟是一個約束,只是保證數據完整性的一個手段。

C. SQL資料庫的、外鍵和查詢

增加外鍵

創建表的時候增加外鍵:在所有的表欄位之後,使用foreign key(外鍵欄位) references 外部表(主鍵欄位)

在新增表之後增加外鍵:修改表結構,使用alter table 表名 add [constraint 外鍵名字] foreign key(外鍵欄位) references 父表(主鍵欄位);

修改外鍵&刪除外鍵

alter table 表名 drop foreign key 外鍵名;

外鍵條件

外鍵要存在,首先必須保證表的存儲引擎是innodb

列類型必須與父表的主鍵類型一致

一張表中的外鍵名字不能重復

增加外鍵的欄位數據已經存在,必須保證數據與父表主鍵要求對應

外鍵約束

有三種約束模式

district:嚴格模式(默認的)

cascade:級聯模式

set null:置空模式

語法:foreign key(外鍵欄位) references 父表(主鍵欄位) on delete 模式 on update 模式;

聯合查詢

基本語法:

select 語句1

union [union 選項]

select 語句2……

union 選項

all:保留所有,不管重復

distinct:去重,默認的

子查詢(sub query)

按位置分類

from子查詢

where子查詢

exists子查詢

按結果分類

標量子查詢

列子查詢

行子查詢

表子查詢

子查詢

列子查詢

=any等價於in; -- 其中一個即可

any等價於some; -- 二者是一樣的

=all為全部

-- 創建外鍵

create table my_foreign1(

idint primary key auto_increment,

name varchar (20)not null comment

'學生姓名',

c_idint comment'班級id',

-- 增加外鍵

foreign key(c_id)references

my_class(id)

)charset utf8;

-- 創建表

create table my_foreign2(

idint primary key auto_increment,

name varchar (20)not null comment

'學生姓名',

c_idint comment'班級id'  -- 普通欄位

)charset utf8;

-- 增加外鍵

alter table my_foreign2add

-- 指定外鍵的名字

constraint student_class_1  -- 可以指定多個外鍵 但是名字不能相同

-- 指定外鍵的欄位

foreign key(c_id)

-- 引用父表主鍵

references my_class(id);

-- 刪除外鍵

alter table my_foreign1drop

foreign key my_foreign1_ibfk_1;  -- my_foreign1_ibfk_1 通過外鍵的名字來刪

-- 插入數據;外鍵欄位在父表不存在

insert into my_foreign2values (

null,'郭富城',4);  -- 沒有4號班級

insert  into my_foreign2values (

null,'項羽',1);

insert  into my_foreign2values (

null,'劉邦',2);

insert  into my_foreign2values (

null,'韓信',3);

-- 更新父表的記錄

update my_classset id=4 where id=1;  -- 失敗;id=1記錄已經被學生引用

update my_foreign2set c_id=2 where id=4;  -- 更新

update my_classset id=4 where id=3;  -- 可以;沒有學生引用此班級

-- mysql中添加外鍵約束遇到一下情況:

-- cannot add foreign key constraint

-- 出現這個問題的原因是,外鍵的使用:

-- 1. 外鍵欄位不能為該表的主鍵;

-- 2. 外鍵欄位參考欄位必須為參考表的主鍵

-- 插入數據

insert into my_foreign1values (

null,'馬超','3'

);

-- 增加外鍵

alter table my_foreign1add

foreign key(c_id)references

my_class(id);  -- 失敗;因為沒有3號班了

-- 創建外鍵,指定模式;刪除置空;更新級聯

create table my_foreign3(

idint primary key auto_increment,

name varchar (20)not null,

c_idint,

-- 增加外鍵

foreign key (c_id)

-- 引用表

references my_class(id)

-- 指定刪除模式

on delete set null

-- 指定更新模式

on update cascade

)charset utf8;

-- 插入數據

insert into my_foreign3values (

null,'劉備',1),

(null,'曹操',1),

(null,'孫權',1),

(null,'祝賀量',2),

(null,'周瑜',2);

-- 解除My_foreign2表的外鍵

alter table my_foreign2drop

foreign key student_class_1;

-- 更新父表主鍵

update my_classset id=3 where id=1;

-- 刪除父表主鍵

delete from  my_classwhere id=2;

-- 聯合查詢

select * from my_class

union  -- 默認去重

select * from my_class;

select * from my_class

union all  -- 不去重

select * from my_class;

select id,c_name,roomfrom my_class

union all  -- 不去重

select name,number,idfrom my_student;

-- 需求;男生升序;女生降序(年齡)

(select * from my_student

where sex='男'

order by ageasc limit9999999)

union

(select * from my_student

where sex='女'

order by agedesc limit9999999);

select * from my_studentwhere

c_id=(

-- 標量子查詢

select idfrom my_classwhere

c_name='python1903');-- id一定只有一個值(一行一列)

insert into my_classvalues (1,

'python1907','B407');

-- 列子查詢

select * from my_studentwhere

c_idin(select idfrom my_class);

-- any,some,all

select * from my_studentwhere

c_id=any(select idfrom my_class);

select * from my_studentwhere

c_id=some(select idfrom my_class);

select * from my_studentwhere

c_id=all(select idfrom my_class);

select * from my_studentwhere

c_id!=any(select idfrom my_class);  -- 所有結果(null除外)

select * from my_studentwhere

c_id!=some(select idfrom my_class);  -- 所有結果(null除外)

select * from my_studentwhere

c_id!=all(select idfrom my_class);  -- 所有2號班級(null除外)

select * from my_studentwhere

age=(select max(age)from

my_student)

and

height=(select max(height))from

my_student);

-- 行子查詢

select * from my_student

-- (age,height)稱之內為行元素

where (age,height)=(select max(

age),max(height)from my_student);

update my_studentset height=188

where name='王五';

select * from my_studentorder by

agedesc,heightdesc limit1;

select * from my_studentorder by

heightdesc;

-- 表子查詢

select * from my_studentgroup by

c_idorder by heightdesc;  -- 每個班選出第一個學生再按身高排序

select * from (select * from

my_studentorder by heightdesc)

as studentgroup by student.c_id;

D. mysql資料庫如何添加外鍵

mysql增加外鍵的方法:1、在CREATE TABLE語句中,通過FOREIGN KEY關鍵字來添加外鍵;2、在ALTER TABLE語句中,通過ADD和FOREIGN KEY關鍵字來添加外鍵。

E. 怎麼為資料庫表添加外鍵

1,創建表的時候添加:foreign key (你的外鍵) references (表名)(欄位名); 2,創建好之後修改: alter table dbo.mh_User add constraint FK_mh_User_..._id foreign key (你的外鍵) references (表名)(欄位名);

F. SQL資料庫外鍵代碼

1.創建主測試表(test_class),

Createtabletest_class(class_idnumber,class_namevarchar2(20));

(6)資料庫添加外鍵擴展閱讀:

1.高可用性:

分布式組織的可擴展性,決策支持的數據倉庫功能,與許多其他伺服器軟體緊密相關的集成,良好的性價比,等等。

2.數據管理和分析的靈活性:

允許單位在快速變化的環境中做出冷靜的反應,從而獲得競爭優勢。從數據管理和分析的角度來看,將原始數據轉換為商業智能並充分利用Web的機會是很重要的。

作為一個完整的資料庫和數據分析軟體包,SQLServer為新一代企業業務應用的快速發展,為企業贏得核心競爭優勢打開了勝利之門。

G. 如何通過sqlyog對資料庫表設置外鍵

要求:建立了兩個表一個attence(記作A表),一個leave(記作L表)。

A表中有用戶的用戶名,密碼,id(自增作為主鍵)。

L表中是一個請假的表,L表中需要標識哪一個用戶請的假。

這里需要設置外鍵:

步驟:

1、

就完成了外鍵的設置。

H. 教你快速掌握DB2資料庫創建外鍵時的選項

免費看《Windows CE 嵌入式系統開發 從基礎到實踐》

創建外鍵時的選項

創建測試表

drop table student;drop table class;drop table student_class;Create table student(student_id integer not null student_name varchar( ) CONSTRAINT P_KEY_ primary key (student_id)) in luzl_ k_tb index in luzl_ k_tb ;Create table class(class_id integer not null class_name varchar( ) CONSTRAINT P_KEY_ primary key (class_id)) in luzl_ k_tb index in luzl_ k_tb ;Create table student_class(student_class_id integer student_id integer class_id integer) in luzl_ k_tb index in luzl_ k_tb;alter table student_class add constraint if_class foreign key(class_id) references class(class_id) ON DELETE cascade ON UPDATE RESTRICT;alter table student_class add constraint if_student foreign key(student_id) references student(student_id) ON DELETE cascade ON UPDATE RESTRICT;Insert into student(student_id student_name) values( luzl );Insert into class(class_id class_name) values( db );Insert into student_class(student_class_id student_id class_id) values( );

On Delete 的選項有

Restrict/no action/cascade/set null 其中cascade選項指定的話 如果刪除父記錄 依賴於他的子記錄也會自動刪除 相當於級聯刪除 如果指定no action和cascade都會報錯 因為還有子記錄所以無法刪除該記錄 set nul允許刪除父記錄並且l會將子表中與父表關聯的欄位設置為null

On Update 只有兩個選項 no action/restrict 它們在更新和刪除時並沒有區別:如果與子表關聯不允許刪除

lishixin/Article/program/DB2/201311/21928

I. 資料庫建表時怎麼設置外鍵

資料庫建表時怎麼設置外鍵步驟如下:
第一步、打開要建外鍵表的設計器,右擊選擇「關系」。
第二步、然後彈出「外鍵關系」窗體,我們選擇「添加」,然後點擊「表和列規范」後面的小按鈕。
第三步、彈出另外一個窗體讓我們選擇主鍵表和列,記住要選擇相同的,選好之後點擊確定。
第四步、展開INSERT和UPDATE規范,在更新規則和刪除規則有四個選項,分別是「不執行任何操作」、「級聯」、「設置為NULL」、「設置默認值」。

J. SQL資料庫建表時怎麼設置外鍵

1>
--
創建測試主表.
ID
是主鍵.
2>
CREATE
TABLE
test_main
(
3>
id
INT,
4>
value
VARCHAR(10),
5>
PRIMARY
KEY(id)
6>
);
7>
go
--
建表時設置外鍵
1>
CREATE
TABLE
test_sub
(
2>
id
INT,
3>
main_id
INT,
4>
value
VARCHAR(10),
5>
PRIMARY
KEY(id),
6>
FOREIGN
KEY
(main_id)
REFERENCES
test_main
7>
);
8>
go

熱點內容
java返回this 發布:2025-10-20 08:28:16 瀏覽:593
製作腳本網站 發布:2025-10-20 08:17:34 瀏覽:888
python中的init方法 發布:2025-10-20 08:17:33 瀏覽:581
圖案密碼什麼意思 發布:2025-10-20 08:16:56 瀏覽:765
怎麼清理微信視頻緩存 發布:2025-10-20 08:12:37 瀏覽:684
c語言編譯器怎麼看執行過程 發布:2025-10-20 08:00:32 瀏覽:1013
郵箱如何填寫發信伺服器 發布:2025-10-20 07:45:27 瀏覽:255
shell腳本入門案例 發布:2025-10-20 07:44:45 瀏覽:114
怎麼上傳照片瀏覽上傳 發布:2025-10-20 07:44:03 瀏覽:806
python股票數據獲取 發布:2025-10-20 07:39:44 瀏覽:712