Heim > Datenbank > MySQL-Tutorial > Oracle 11g 第十章知识点总结约束

Oracle 11g 第十章知识点总结约束

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
Freigeben: 2016-06-07 15:31:07
Original
1102 Leute haben es durchsucht

Oracle 11g 第十章知识点总结——约束 知识点预览 复习 约束 复习 --主键primarykey--(非空唯一) --唯一能够标识表里的一条记录--非空 not null--唯一性约束unique--检查约束 check(gender in('男','女')) --外键 --当前表里的这个外键是另外一张表里的主键

Oracle 11g 第十章知识点总结——约束


知识点预览

 

复习

约束

 

复习


1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

--主键

primarykey

--(非空+唯一)

         --唯一能够标识表里的一条记录

--非空

         not null

--唯一性约束

unique

--检查约束

         check(gender in('男','女'))

         

--外键

         --当前表里的这个外键是另外一张表里的主键

         --必须和哪个主键的数据类型和长度保持一致

  

  

--删除表

         drop table table_name

         --产生乱码

         purge table "BIN$2RcRpY2KSLy+FONALkCBUw==$0";

         purge table t_tes;--错误

         

  

--DBA

  

         

--创建表

--分类表

--基表

                   

                            create tablecategory (

                                     idnumber(3) primary key,

                                     namevarchar2(20) not null

                            );

--产品表

--从表

                   

                            create table product(

                                     idnumber(10) primary key,

                                     namevarchar2(20) not null,

                                     cidnumber(3),

                                     constraintscott_product_cid_FK foreign key(cid) references category(id)

                            );

                            

                   insert into categoryvalues(1,'电脑');

                   insert into productvalues(1,'IBM',1);

                   

                   insert into categoryvalues(2,'食品');

                   insert into productvalues(2,'牛肉干',2);

                   

--删除

--先删除从表数据

--后删主表数据

       delete category where id=1;

Nach dem Login kopieren



约束


1.      什么是约束

a)        约束是表级的强制规定

b)       约束放置在表中删除有关联关系的数据

c)        有以下五种约束:

                                     i.             NOT NULL

                                   ii.             UNIQUE

                                 iii.             PRIMARY KEY

                                  iv.             FOREIGN KEY

                                    v.             CHECK


2.      注意事项

a)        如果不指定约束名 Oracle server 自动按照 SYS_Cn 的格式指定约束名

b)       在什么时候创建约束:

                                     i.             建表的同时

                                   ii.             建表之后

c)        可以在表级或列级定义约束

d)       可以通过数据字典视图查看约束


3.      定义约束

 

a)        语法

CREATE TABLE[schema.]table

    (columndatatype [DEFAULT expr]

        [column_constraint],

        ...

        [table_constraint][,...]);

 

1

2

3

4

5

6

7

CREATE TABLEemployees(

            employee_id  NUMBER(6),

         first_name   VARCHAR2(20),

            ...

            job_id       VARCHAR2(10) NOT NULL,

    CONSTRAINT emp_emp_id_pk

                     PRIMARYKEY (EMPLOYEE_ID));

Nach dem Login kopieren


 

b)       列级

 

column [CONSTRAINT constraint_name]constraint_type,

 

c)        列级

 

column,...

  [CONSTRAINT constraint_name]constraint_type

  (column, ...),

 

4.      NOT NULL 约束

 

a)        保证列值不能为空:

b)       只能定义在列级:


 Oracle 11g 第十章知识点总结约束


 

5.      UNIQUE 约束

 

可以定义在表级或列级:

 

1

2

3

4

5

6

7

8

9

CREATE TABLE employees(

    employee_id      NUMBER(6),

    last_name        VARCHAR2(25) NOT NULL,

    email            VARCHAR2(25) ,

    salary           NUMBER(8,2),

    commission_pct   NUMBER(2,2),

    hire_date        DATE NOT NULL,

...

    CONSTRAINT emp_email_uk UNIQUE(email));

Nach dem Login kopieren


6.      PRIMARY KEY 约束

 

可以定义在表级或列级:

 

1

2

3

4

5

6

7

CREA TETABLE   departments(

    department_id        NUMBER(4),

    department_name      VARCHAR2(30)

      CONSTRAINT dept_name_nn NOT NULL,

    manager_id           NUMBER(6),

    location_id          NUMBER(4),

      CONSTRAINT dept_id_pk PRIMARYKEY(department_id));

Nach dem Login kopieren


7.      FOREIGN KEY 约束

 

可以定义在表级或列级:

 

1

2

3

4

5

6

7

8

9

10

11

12

CREATE TABLEemployees(

    employee_id      NUMBER(6),

    last_name        VARCHAR2(25) NOT NULL,

    email            VARCHAR2(25),

    salary           NUMBER(8,2),

    commission_pct   NUMBER(2,2),

    hire_date        DATE NOT NULL,

...

    department_id    NUMBER(4),

    CONSTRAINT emp_dept_fk FOREIGN KEY(department_id)

      REFERENCES departments(department_id),

    CONSTRAINT emp_email_uk UNIQUE(email));

Nach dem Login kopieren


8.      FOREIGN KEY 约束的关键字

a)        FOREIGN KEY: 在表级指定子表中的列

b)       REFERENCES: 标示在父表中的列

c)        ON DELETE CASCADE: 当父表中的列被删除是,子表中相对应的列也被删除

d)       ON DELETE SET NULL: 子表中相应的列置空


9.      CHECK 约束

a)        定义每一行必须满足的条件

b)       以下的表达式是不允许的:

                                     i.             出现CURRVAL, NEXTVAL, LEVEL, 和ROWNUM 伪列

                                   ii.             使用 SYSDATE, UID, USER, 和 USERENV 函数

                                 iii.             在查询中涉及到其它列的值

 

 

1

2

3

..., salary NUMBER(2)

     CONSTRAINT emp_salary_min

            CHECK (salary > 0),...

Nach dem Login kopieren


10.  添加约束的语法

 

使用 ALTER TABLE 语句:

添加或删除约束, 但是不能修改约束

有效化或无效化约束

添加 NOT NULL 约束要使用 MODIFY 语句

 

ALTER TABLE    table

      ADD [CONSTRAINT constraint]type (column);

 

11.  添加约束举例

 

1

2

3

4

ALTER TABLE     employees

ADDCONSTRAINT  emp_manager_fk

  FOREIGN KEY(manager_id)

  REFERENCES employees(employee_id);

Nach dem Login kopieren


Table altered.


12.  删除约束

a)        表 EMPLOYEES 中删除约束

 

1

2

ALTER TABLE      employees

DROPCONSTRAINT  emp_manager_fk;

Nach dem Login kopieren


Table altered.

b)       使用CASCADE选项删除约束

 

1

2

ALTER TABLE      departments

DROP PRIMARY KEYCASCADE;

Nach dem Login kopieren


Table altered.


13.  无效化约束

a)        在ALTER TABLE 语句中使用 DISABLE 子句将约束无效化。

b)       使用 CASCADE 选项将相关的约束也无效化

1

2

ALTER TABLE             employees

DISABLE CONSTRAINT     emp_emp_id_pk CASCADE;

Nach dem Login kopieren


Table altered.


14.  激活约束

a)        ENABLE 子句可将当前无效的约束激活

 

1

2

ALTER TABLE             employees

ENABLECONSTRAINT      emp_emp_id_pk;

Nach dem Login kopieren


Table altered.

b)       当索引定义或激活UNIQUE 或 PRIMARY KEY 约束时系统会自动创建UNIQUE 或 PRIMARY KEY

 

15.  及连约束

a)        CASCADE CONSTRAINTS 子句在 DROP COLUMN 子句中使用

b)       在删除表的列时 CASCADE CONSTRAINTS 子句指定将相关的约束一起删除

c)        在删除表的列时 CASCADE CONSTRAINTS 子句同时也删除多列约束

 

d)       及连约束举例:

 

 

1

2

ALTER TABLEtest1

DROP (pk)CASCADE CONSTRAINTS;

Nach dem Login kopieren


Table altered.

 

1

2

ALTER TABLEtest1

DROP (pk, fk,col1) CASCADE CONSTRAINTS;

Nach dem Login kopieren


Table altered.


16.  查询约束

 

查询数据字典视图 USER_CONSTRAINTS

 

1

2

3

4

SELECT  constraint_name, constraint_type,

search_condition

FROM     user_constraints

WHERE   table_name = 'EMPLOYEES';

Nach dem Login kopieren


17.  查询定义约束的列

 

查询数据字典视图 USER_CONS_COLUMNS

 

1

2

3

SELECT  constraint_name, column_name

FROM     user_cons_columns

WHERE   table_name = 'EMPLOYEES';

Nach dem Login kopieren


 


Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage