oracle如何操作约束
自我总结,欢迎怕转!
约束的作用不多说了,直接看怎么用吧。
非空约束:
在创建表时设置非空约束:
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;
oracle如何操作约束的更多相关文章
- Oracle 数据完整性与约束机制
为了维护数据库数据的完整性,在创建表时需要定义一些约束,Oracle中的约束类型包括:非空约束.主键约束.唯一约束.外键约束等.在对约束操作前,我们可以通过表名查询它具有的约束信息. 表约束 SELE ...
- Oracle—表、约束、索引、表空间、分区、序列、统计信息
表.约束.索引.表空间.分区.序列.统计信息 一.表及其操作 1.创建表 create table 表名 ( 字段名1 字段类型 默认值 是否为空 , 字段名2 字段类型 默认值 是否为空, 字段名3 ...
- [转]Oracle 树操作(select…start with…connect by…prior)
转自http://www.cnblogs.com/linjiqin/archive/2013/06/24/3152674.html Oracle 树操作(select-start with-conne ...
- Oracle列操作(增加列,修改列,删除列)
Oracle列操作 增加一列: alter table emp4 add test varchar2(10); 修改一列: alter table emp4 modify test varchar2( ...
- 基于OCILIB的oracle数据库操作总结及自动生成Model和Dao的工具
基于OCILIB的oracle数据库操作总结 1. 类图 2. 基类BaseOCIDao的设计与实现 BaseOCIDao.h头文件 #pragma once /* ----- ...
- Oracle集合操作函数:union、intersect、minus
[转]Oracle集合操作函数:union.intersect.minus 集合操作符专门用于合并多条select 语句的结果,包括:UNION, UNION ALL, INTERSECT, MINU ...
- Oracle 树操作
Oracle 树操作(select…start with…connect by…prior) oracle树查询的最重要的就是select…start with…connect by…prior语法了 ...
- Oracle字符串操作[转:http://www.cnblogs.com/xd502djj/archive/2010/08/11/1797577.html]
ORACLE 字符串操作 1 字符串连接 SQL> select 'abc' || 'def' from dual; 'ABC'|------abcdef 2 小写SQL>select ...
- C# Oracle数据库操作类实例详解
本文所述为C#实现的Oracle数据库操作类,可执行超多常用的Oracle数据库操作,包含了基础数据库连接.关闭连接.输出记录集.执行Sql语句,返回带分页功能的dataset .取表里字段的类型和长 ...
随机推荐
- 关于jmeter工具使用的总结
今天总结下jmeter工具如何使用 先从最简单的说起 如何打开jemter 配置环境变量 接下来我们只要在dos窗口中输入 jmeter就能打开,这也告诉了我们配置环境变量的方便性 接下来介绍一下线程 ...
- 循序渐进之Spring AOP(1) - 原理
AOP全称是Aspect Oriented Programing,通常译为面向切面编程.利用AOP可以对面向对象编程做很好的补充. 用生活中的改装车比喻,工厂用面向对象的方法制造好汽车后,车主往往有些 ...
- JavaScript中的this(你不知道的JavaScript)
JavaScript中的this,刚接触JavaScript时大家都在大肆渲染说其多么多么的灵巧重要,然而自己并不关心:随着自己对JavaScript一步步深入了解,突然恍然大悟,原来它真的很重要!所 ...
- Ubuntu环境下IPython的搭建和使用
1. Ubuntu操作系统版本 说明:Ubuntu 12.04.3 LTS自带的Python 2.7.3版本. 2. 安装IPython 说明: 输入命令sudo apt-get install ip ...
- [bzoj4098] [Usaco2015 Open]Palindromic Paths
DP.. f[i][j][k]表示左上结束节点是第i条副对角线上的第j个点,右下结束节点是第n*2-i条副对角线上的第k个点,构成回文的方案数. i那维滚动一下.时间复杂度O(n^3)空间复杂度O(n ...
- Hat's Fibonacci(大数加法+直接暴力)
题目连接:http://acm.hdu.edu.cn/showproblem.php?pid=1250 hdu1250: Hat's Fibonacci Time Limit: 2000/1000 M ...
- 初识LINUX之常见命令
玩过Linux的人都会知道,Linux中的命令的确是非常多,但是玩过Linux的人也从来不会因为Linux的命令如此之多而烦恼,因为我们只需要掌握我们最常用的命令就可以了.当然你也可以在使用时去找一下 ...
- UEP-标签
这里的标签都是常用不好理解的: formatfunc="showFormatNumer" 显示数字在页面上 ockedcolumnnum="6" 几列是不动的 ...
- spring boot容器启动详解
目录 一.前言 二.容器启动 三.总结 =======正文分割线====== 一.前言 spring cloud大行其道的当下,如果不了解基本原理那么是很纠结的(看见的都是约定大于配置,但是原理呢?为 ...
- php-cli和php-fpm的关系是什么?
CLI是命令行版本.FPM是作为Apache或者Nginx等服务器软件处理PHP文件的扩展. PHP的默认版本是不支持线程安全的,这个线程安全问题可以去了解PHP扩展开发方面的相关知识,这是因为C语言 ...