SQL语言创建表时候怎么定义主码和外码

SQL语言创建表时候怎么定义主码和外码,第1张

SQL语言创建表时候用Primary Key(属性名)定义主码,用Foreign Key(属性名)定义外码。

主码是一种唯一关键字,表定义的一部分。一个表的主码可以由多个关键字共同组成,并且主码的列不能包含空值。主码是可选的,并且可在 CREATE TABLE语句中用Primary Key(属性名)定义。

将一个表的值放入第二个表来表示关联,所使用的值是第一个表的主键值(在必要时可包括复合主键值)。此时,第二个表中保存这些值的属性称为外键,用Foreign Key(属性名)定义。

如:

CREATE TABLE Customer

(SID integer,

CID integer,

Last_Name varchar(30),

First_Name varchar(30),

PRIMARY KEY (SID),Foreign Key(CID 名));

扩展资料:

主码不应包含动态变化的数据,如时间戳、创建时间列、修改时间列等。实际上,因为主码除了唯一地标识一行之外,再没有其他的用途了,所以也就没有理由去对它更新。如果主码需要更新,则说明主码应对用户无意义的原则被违反了。

主码应当由计算机自动生成。如果由人来对主码的创建进行干预,就会使它带有除了唯一标识一行以外的意义。一旦越过这个界限,就可能产生人为修改主码的动机,这样,这种系统用来链接记录行、管理记录行的关键手段就会落入不了解数据库设计的人的手中。

1.创建主测试表(test_class),

Createtabletest_class(class_idnumber,class_namevarchar2(20));

2.创建test100子表(学生表test_student),

Createtabletest_student(stu_idnumber,stu_namevarchar2(200),class_idnumber);

3.向主表(类表test_class)添加唯一的主键,

altertableTEST_CLASS

Addconstraintpk_class_idprimarykey(CLASS_ID);

4.子表(test_student)创建一个外键,

alter表TEST_STUDENT

添加约束fk_class_id外键(CLASS_ID)

参考test_class(CLASS_ID);

扩展资料:

1.高可用性:

分布式组织的可扩展性,决策支持的数据仓库功能,与许多其他服务器软件紧密相关的集成,良好的性价比,等等。

2.数据管理和分析的灵活性:

允许单位在快速变化的环境中做出冷静的反应,从而获得竞争优势。从数据管理和分析的角度来看,将原始数据转换为商业智能并充分利用Web的机会是很重要的。

作为一个完整的数据库和数据分析软件包,SQLServer为新一代企业业务应用的快速发展,为企业赢得核心竞争优势打开了胜利之门。

USE

D

--

咱们一下的 *** 作都是在数据库

D

中进行的。

GO

--学生表:

CREATE

TABLE

Student(

sid

int

primary

key,

sname

varchar(20)

)

--课程表:

CREATE

TABLE

Course(

cid

int

primary

key,

cname

varchar(20)

)

--成绩表:

CREATE

TABLE

Grade(

sid

int

,

cid

int

,

score

int

)

--因为:1个学生+1个课程=1个成绩。

--因此:Grade表是子表,Student和Course是父表。

--给成绩表增加外键约束:

ALTER

TABLE

Grade

ADD

CONSTRAINT

Student_Grade_sid_fk

FOREIGN

KEY(sid)

REFERENCES

Student(sid)

ALTER

TABLE

Grade

ADD

CONSTRAINT

Course_Grade_cid_fk

FOREIGN

KEY(cid)

REFERENCES

Course(cid)

注意:如果Grade表中现有的数据违反了你要加入的约束。

则约束就会添加失败。

解决的方法:

将表中违反约束的数据删掉后就可以了。


欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/bake/11365574.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-15
下一篇 2023-05-15

发表评论

登录后才能评论

评论列表(0条)

保存