1. 程式人生 > >mysql中建立約束語法,建表時,建表後

mysql中建立約束語法,建表時,建表後

主鍵、外來鍵和索引的區別

定義:

主鍵--唯一標識一條記錄,不能有重複的,不允許為空

外來鍵--表的外來鍵是另一表的主鍵外來鍵可以有重複的可以是空值

索引--該欄位沒有重複值,但可以有一個空值

作用:

主鍵--用來保證資料完整性

外來鍵--用來和其他表建立聯絡用的

索引--是提高查詢排序的速度

個數:

主鍵--主鍵只能有一個

外來鍵--一個表可以有多個外來鍵

索引--一個表可以有多個唯一索引

建立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 add constraint FK_B foreign key (ticket_no) references B(ticket_no)

alter table 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'

MySQL:

mysql建表語句是最基礎的SQL語句之一,下面就為您介紹最常用的三種MySQL建表語句,如果您對MySQL建表語句方面感興趣的話,不妨一看。

1、最簡單的:

CREATE TABLE t1(
    id int not null,
    name char(20)
);
2、帶主鍵的:

a:
CREATE TABLE t1(
    id int not null primary key,
    name char(20)
);
b:複合主鍵
CREATE TABLE t1(
    id int not null,
    name char(20),
    primary key (id,name)
);
3、帶預設值的:

CREATE TABLE t1(
    id int not null default 0 primary key,
    name char(20) default '1'
);