时间:2021-07-01 10:21:17 帮助过:2人阅读
CREATE TABLE member ( mid NUMBER PRIMARY KEY, name VARCHAR2(200) NOT NULL, address VARCHAR2(200), zipcode VARCHAR2(6), mobile VARCHAR2(20), tel VARCHAR2(20) );
但是在这里面有两点需要说明:
所谓不可分割指的是所有的数据类型都使用数据库提供好的各个数据类型。
二、第二范式:多对多
第二范式:数据表中的非关键字段存在对任一候选关键字段的部分函数依赖;
第二范式分为两种方式理解:
CREATE TABLE orders ( oid NUMBER PRIMARY KEY, amount NUMBER, price NUMBER, allprice NUMBER );
现在的商品总价(allprice)=商品单价(price)*商品数量(amount),所以存在了函数的依赖关系;
CREATE TABLE studentcourse ( stuid NUMBER PRIMARY KEY, stuname VARCHAR2(20) NOT NULL, cname VARCHAR2(50) NOT NULL, credit NUMBER NOT NULL, score NUMBER ); INSERT INTO studentcourse (stuid,stuname,cname,credit,score) VALUES (1,‘张三‘,‘Java‘,3,89); INSERT INTO studentcourse (stuid,stuname,cname,credit,score) VALUES (2,‘李四‘,‘Java‘,3,99); INSERT INTO studentcourse (stuid,stuname,cname,credit,score) VALUES (3,‘王五‘,‘Java‘,3,78); INSERT INTO studentcourse (stuid,stuname,cname,credit,score) VALUES (1,‘张三‘,‘Oracle‘,1,79); INSERT INTO studentcourse (stuid,stuname,cname,credit,score) VALUES (2,‘李四‘,‘Oracle‘,1,89);
这种设计符合于第一设计范式,但是不符合于第二范式,因为程序会存在如下的错误:
如果要想解决此问题,则可以将数据表的设计修改如下:
CREATE TABLE student ( stuid NUMBER PRIMARY KEY, stuname VARCHAR2(20) NOT NULL ); CREATE TABLE course ( cid NUMBER PRIMARY KEY, cname VARCHAR2(50) NOT NULL, credit NUMBER NOT NULL ); CREATE TABLE studentcourse ( stuid NUMBER REFERENCES student(stuid), cid NUMBER REFERENCES course(cid), score NUMBER ); INSERT INTO student (stuid,stuname) VALUES (1,‘张三‘); INSERT INTO student (stuid,stuname) VALUES (2,‘李四‘); INSERT INTO student (stuid,stuname) VALUES (3,‘王五‘); INSERT INTO course (cid,cname,credit) VALUES (10,‘Java‘,3); INSERT INTO course (cid,cname,credit) VALUES (11,‘Oracle‘,1); INSERT INTO course (cid,cname,credit) VALUES (12,‘Linux‘,2); INSERT INTO studentcourse (stuid,cid,score) VALUES (1,10,89); INSERT INTO studentcourse (stuid,cid,score) VALUES (2,10,99); INSERT INTO studentcourse (stuid,cid,score) VALUES (3,10,78); INSERT INTO studentcourse (stuid,cid,score) VALUES (1,11,79); INSERT INTO studentcourse (stuid,cid,score) VALUES (2,11,89);
这种设计与之前讲解运动会-项目-成绩的设计是一样的。
三、第三范式:一对多
例如,现在一个学校有多个学生,如果用第一范式无法实现,而如果用第二范式则表示多对多的关系,即:一个学校有多个学生,一个学生在多个学校,不符合于要求,所以此时可以使用第三范式,参考之前的部门和雇员操作实现,一个部门有多个雇员,所以按照设计编写如下:
CREATE TABLE school ( sid NUMBER PRIMARY KEY, sname VARCHAR2(20) NOT NULL ); CREATE TABLE student ( stuid NUMBER PRIMARY KEY, stuname VARCHAR2(20) NOT NULL, sid NUMBER REFERENCES school(sid) );
而在实际的工作之中,第三范式的使用是最多的。
以上的三个范式只是作为参考使用
Oracle三大范式
标签: