oracle如何操作约束
2017-02-19 13:41
375 查看
自我总结,欢迎怕转!
约束的作用不多说了,直接看怎么用吧。
非空约束:
在创建表时设置非空约束:
CREATE TABLE table_name( column_name datatype NOT NULL)
在修改表时添加非空约束:
ALTER TABLE table_name MODIFY column_name datatype NOT NULL
在修改表时去除非空约束:
ALTER TABLE table_name MODIFY column_name dataypte NULL
主键约束:
作用:确保表种每一行数据的唯一性
在创建表时设置主键约束:
1) CREATE TABLE table_name(column_name dataype PRIMARY KEY)
2) CONSTRAINT constraint_name PRIMARY KEY(column_name1,..)
查看约束 SELECT constraint_name FROM USER_CONSTRAINTS WHERE table_name = 'student'
在修改表时添加主键约束:
ALTER TABLE student ADD CONSTRAINT constraint_name PRIMARY KEY(column_name1,...)
更改约束名称 :
ALTER TABLE student RENAME CONSTRAINT old_name to new_name
删除主键约束:
暂时不用:ALTER TABLE student DISABLE|ENABLE CONSTRAINT constraint_name
直接删除:1)ALTER TABLE student DROP CONSTRAINT constraint_name
2) ALTER TABLE student DROP PRIMARY KEY [CASCADE]
查看约束状态: SELECT CONSTRAINT_NAME,STATUS FROM USER_CONSTRAINTS WHERE table_name = 'student'
外键约束:
在创建表时设置外键约束:
1) CREATE TABLE table1 (column_name datatype REFERENCES table2(column_name))
条件: 主表table2中的字段必须是主键
主从表table1中的字段类型必须也主表table2中的字段类型一致
主从表table1中字段的值必须全部来自主表table2中相应的字段,或NULL值
2) CONSTRAINT constraint_name FOREIGN KEY(column_name ) REFERENCES table_name(column_name1) [ ON DELETE CASCADE] //级联删除 主表数据中的数据被删除时,从表中引用的字段的行数据也删除
在修改表时设置外键约束:
ALTER TALBLE student ADD CONSTRAINT constraint_name FOREIGN KEY(column_name) REFERENCES table2(column_name) [ ON DELETE CASCADE ]
删除外键约束:
暂时不用:ALTER TABLE student DISABLE | ENABLE CONSTRAINT constraint_name
直接删除:ALTER TABLE student DROP CONSTRAINT constrain_name
唯一约束:
主键约束与唯一性约束的区别:
主键字段值必须为非空,唯一性约束允许有一个空值
主键约束在每张表中只能有一个,唯一性约束在每张表中可以有多个
在创建表时设置唯一性约束:
1) CREATE TABLE table_name (column_name datatype UNIQUE,...)
2) CONSTRAINT constraint_name UNIQUE(column_name) //该语句只能设置一个字段,要想设置其他字段必须新创建唯一性约束
在修改表时设施唯一性约束:
ALTER TABLE student CONSTRAINT constraint_name UNIQUE(column_name)
删除唯一性约束:
暂时禁用: ALTER TABLE student DISABLE |ENABLE CONSTRAINT constraint_name
直接删除: ALTER TABLE student DORP CONSTRAINT constraint_name
检查约束:
作用:让表中的值更有实际意义
在创建表时设置检查约束:
1) CREATE TALBE table_name (column_name datatype CHECK(money > 0))
2) CONSTRAINT constraint_name CHECK(money > 0)
在修改表时设置检查约束:
ALTER TABLE student ADD CONSTRAINT constraint_name CHECK(money > 0)
删除检查约束:
暂时禁用: ALTER TABLE student DISABLE | ENABLE CONSTRAINT constrain_name
直接删除: ALTER TABLE student DROP CONSTRIAN constraint_name
其他知识点:
数据类型:
字符型:
CHAR(n):固定长度 , MAX :2000
NCHAR(n):固定长度,按照Unicode格式存放数据的,用于存放汉字,MAX:1000
VARCHAR2(n):可变长度, MAX : 4000
NVARCHAR2(n): 可变长度,按照Unicode格式存放数据的 MAX: 2000
数值型:
NUMBER(p,s):p->有效数字 ; s > 0 小数后的位数 s < 0 最大有效数字到小数点的位数
FLOAT(n) :用来存放二进制数据的,能够表示二进制的1~126位 ,若要若要转换成十进制 则需要乘以 0.30103
日期型:
DATA: 精确到秒(常用)
TIMESTAMP:精确到小数秒
其他类型:
BLOB: MAX : 4G 以二进制格式存放
CLOB: MAX : 4G 以字符串格式存放
给表改名:
rename old_name to new_name
清空表:
TRUNCATE TABLE table_name
日期字段:
regdate date default sysdate
修改表字段:
ALTER TABLE table_name modify email default '无';
复制表数据:
创建表时复制:
CREATE TABLE table_new AS SELECT column1,...|* FROM table_old
eg. CREATE TABLE TEST007 AS SELECT * FROM STUDENT;
在添加数据是复制:
INSET INTO table_new [(column1,...)] SELECT column1,...|* FROM table_old;
eg. INSERT INTO STUDENT (ID,NAME) SELECT ID,NAME FROM TEST007;
INSERT INTO STUDENT SELECT * FROM TEST007;
约束的作用不多说了,直接看怎么用吧。
非空约束:
在创建表时设置非空约束:
CREATE TABLE table_name( column_name datatype NOT NULL)
在修改表时添加非空约束:
ALTER TABLE table_name MODIFY column_name datatype NOT NULL
在修改表时去除非空约束:
ALTER TABLE table_name MODIFY column_name dataypte NULL
主键约束:
作用:确保表种每一行数据的唯一性
在创建表时设置主键约束:
1) CREATE TABLE table_name(column_name dataype PRIMARY KEY)
2) CONSTRAINT constraint_name PRIMARY KEY(column_name1,..)
查看约束 SELECT constraint_name FROM USER_CONSTRAINTS WHERE table_name = 'student'
在修改表时添加主键约束:
ALTER TABLE student ADD CONSTRAINT constraint_name PRIMARY KEY(column_name1,...)
更改约束名称 :
ALTER TABLE student RENAME CONSTRAINT old_name to new_name
删除主键约束:
暂时不用:ALTER TABLE student DISABLE|ENABLE CONSTRAINT constraint_name
直接删除:1)ALTER TABLE student DROP CONSTRAINT constraint_name
2) ALTER TABLE student DROP PRIMARY KEY [CASCADE]
查看约束状态: SELECT CONSTRAINT_NAME,STATUS FROM USER_CONSTRAINTS WHERE table_name = 'student'
外键约束:
在创建表时设置外键约束:
1) CREATE TABLE table1 (column_name datatype REFERENCES table2(column_name))
条件: 主表table2中的字段必须是主键
主从表table1中的字段类型必须也主表table2中的字段类型一致
主从表table1中字段的值必须全部来自主表table2中相应的字段,或NULL值
2) CONSTRAINT constraint_name FOREIGN KEY(column_name ) REFERENCES table_name(column_name1) [ ON DELETE CASCADE] //级联删除 主表数据中的数据被删除时,从表中引用的字段的行数据也删除
在修改表时设置外键约束:
ALTER TALBLE student ADD CONSTRAINT constraint_name FOREIGN KEY(column_name) REFERENCES table2(column_name) [ ON DELETE CASCADE ]
删除外键约束:
暂时不用:ALTER TABLE student DISABLE | ENABLE CONSTRAINT constraint_name
直接删除:ALTER TABLE student DROP CONSTRAINT constrain_name
唯一约束:
主键约束与唯一性约束的区别:
主键字段值必须为非空,唯一性约束允许有一个空值
主键约束在每张表中只能有一个,唯一性约束在每张表中可以有多个
在创建表时设置唯一性约束:
1) CREATE TABLE table_name (column_name datatype UNIQUE,...)
2) CONSTRAINT constraint_name UNIQUE(column_name) //该语句只能设置一个字段,要想设置其他字段必须新创建唯一性约束
在修改表时设施唯一性约束:
ALTER TABLE student CONSTRAINT constraint_name UNIQUE(column_name)
删除唯一性约束:
暂时禁用: ALTER TABLE student DISABLE |ENABLE CONSTRAINT constraint_name
直接删除: ALTER TABLE student DORP CONSTRAINT constraint_name
检查约束:
作用:让表中的值更有实际意义
在创建表时设置检查约束:
1) CREATE TALBE table_name (column_name datatype CHECK(money > 0))
2) CONSTRAINT constraint_name CHECK(money > 0)
在修改表时设置检查约束:
ALTER TABLE student ADD CONSTRAINT constraint_name CHECK(money > 0)
删除检查约束:
暂时禁用: ALTER TABLE student DISABLE | ENABLE CONSTRAINT constrain_name
直接删除: ALTER TABLE student DROP CONSTRIAN constraint_name
其他知识点:
数据类型:
字符型:
CHAR(n):固定长度 , MAX :2000
NCHAR(n):固定长度,按照Unicode格式存放数据的,用于存放汉字,MAX:1000
VARCHAR2(n):可变长度, MAX : 4000
NVARCHAR2(n): 可变长度,按照Unicode格式存放数据的 MAX: 2000
数值型:
NUMBER(p,s):p->有效数字 ; s > 0 小数后的位数 s < 0 最大有效数字到小数点的位数
FLOAT(n) :用来存放二进制数据的,能够表示二进制的1~126位 ,若要若要转换成十进制 则需要乘以 0.30103
日期型:
DATA: 精确到秒(常用)
TIMESTAMP:精确到小数秒
其他类型:
BLOB: MAX : 4G 以二进制格式存放
CLOB: MAX : 4G 以字符串格式存放
给表改名:
rename old_name to new_name
清空表:
TRUNCATE TABLE table_name
日期字段:
regdate date default sysdate
修改表字段:
ALTER TABLE table_name modify email default '无';
复制表数据:
创建表时复制:
CREATE TABLE table_new AS SELECT column1,...|* FROM table_old
eg. CREATE TABLE TEST007 AS SELECT * FROM STUDENT;
在添加数据是复制:
INSET INTO table_new [(column1,...)] SELECT column1,...|* FROM table_old;
eg. INSERT INTO STUDENT (ID,NAME) SELECT ID,NAME FROM TEST007;
INSERT INTO STUDENT SELECT * FROM TEST007;
相关文章推荐
- 如何在Hibernate当中操作Oracle Clob
- 如何在oracle里面操作BLOB
- Oracle初学者需要知道的常用数据表如EMP、DEPT、SALGRADE等是如何操作的?图解操作
- 对oracle当中子查询建表,merge操作,创建,修改,删除约束,创建使用触发器的复习练习
- oracle:表、列、约束等操作,table,constraint,column
- Oracle如何操作LOB
- oracle的segments(表、字段、约束、索引)操作
- 如何启用和禁用oracle&DB2数据库外键约束(转)
- 如何用SQL操作oracle的blob字段里的字符串数据!
- oracle中关于表的所有操作(创建删除表,修改表结构,创建约束,操作表数据,增删改查等)
- oracle如何实现主键的自增1操作
- Oracle PL\SQL操作(四)索引与约束
- oracle里如何快速drop column测试(慎用于生产系统,该操作导致表无法访问)
- Oracle 约束的相关操作
- oracle中关于表的所有操作(创建删除表,修改表结构,创建约束,操作表数据,增删改查等)
- 如何创建和操作Oracle 数据库分区表
- ABAP--如何通过Oracle游标直接操作Oracle的系统表
- Oracle PL/SQL操作(四)索引与约束
- oracle day3:如何对表进行增删改询操作
- Oracle如何实现创建数据库、备份数据库及数据导出导入的一条龙操作