sqlreference
① 資料庫sql語言中,foreign key和references的區別是什麼
假設兩張表,表1(學號,姓名,性別),學號為主鍵. 表2(學號,課程,成績). 可以為表2的學號定義外鍵(FOREIGN KEY),該外鍵的取值范圍參照(REFERENCES)表1的學號
CONSTRAINT是對某列定義約束, 如上表1中的"性別",可以定義約束,將取值限定為不是"男",就是"女". CHECK(性別 IN ('男','女'))
② 關於資料庫語言SQL中references的用法
這樣寫的意思應該是本表的Cpno是外鍵,參照本表的Cno主鍵。這樣建立的不是兩個表外鍵關系,而是同一個表。我覺得這樣S、T和C之間的實體關系有些亂。理順course.student和teacher之間的關系是正確添加外鍵的關鍵。
如何添加表的外鍵關系,請看如下實例:
CREATE DATABASE CLOTH_INFO
CREATE TABLE User_info
(
id INT(4) NOT NULL AUTO_INCREMENT,
PRIMARY KEY (id)(主鍵)
)
CREATE TABLE cloth_info(
id_number INT(4) NOT NULL AUTO_INCREMENT,
PRIMARY KEY(id_number)(主鍵)
)
CREATE TABLE cloth_sale_info(
id_number INT(4) NOT NULL,
cloth_id INT(4) REFERENCES cloth_info(id_number),(外鍵)
user_id INT(4) REFERENCES User_info(id)(外鍵)
)
CREATE TABLE cloth_store_info(
id_number INT(4) NOT NULL ,
cloth_id INT(4) REFERENCES cloth_info(id_number)(外鍵)
)
③ sql references什麼意思
單獨一個單詞在sql中並沒有什麼含義,references是在為表創建外鍵時的一個固定語法里的詞度。
作用
保持數據一致性,完整性,主要目的是控制存儲在外鍵表中的數據。 使兩張表形成關聯,外鍵只能引用外表中的列的值或使用空值。
學號在成績表中是主鍵,在學生表中是外鍵。如果不使用外鍵,表1的學號欄位插了一個值(比如20140999999),但是這個值在表2中並沒有,這個時候,資料庫允許插入,並不會對插入的數據做關系檢查。
④ sql為什麼reference語句無效
因為起到了混淆作用。無效的表別名或者列引用,因為在我的sql中dev是表名起到了混淆作用,因此一開始並沒有反應過來。