Oracle Database 完整性约束


非空约束

创建表时

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 datatype null;

主键约束

创建表时

Create table table_name(

Column_name datatype PRIMARY KEY,…

);

创建表时

Create table table_name(

Column_name datatype ,…,

CONSTRAINT constraint_name PRIMARY KEY(column_name1,…)

);

Desc user_constraints;查看约束数据字典

在修改表时添加

Alter table table_name

Add constraint constraint_name primary key(column_name1,…);

更新主键名字

Alter table table_name

Rename constraint old_name to new _name;

禁用主键约束

Alter table table_name

Disable|enable constraint constraint_name

删除主键约束

Alter table table_name

Drop constraint constraint_name

Drop primary key[cascade]

在创建表时设置外键约束

Create table table1(

Column_name datatype REFERENCES table2(column_name),..)

Constraint constraint_name foreign key(column_name)

References

Table_name(column_name) [on delete cascade]

在修改表时添加外键约束

Alter table table_name

Add Constraint constraint_name foreign key(column_name)

References

Table_name(column_name) [on delete cascade]

禁用外键约束

Alter table table_name

Disable|enable constraint constraint_name

删除外键约束

Alter table table_name

Drop constraint constraint_name

在创建表时设置唯一约束

Create table table_name(column_name datatype UNIQUE,..)

Constraint constraint_name UNIQUE(column_name)

在修改表时添加唯一约束

Alter table table_name

Add Constraint constraint_name UNIQUE (column_name)

删除唯一约束

禁用唯一约束

Alter table table_name

Disable|enable constraint constraint_name

删除外键约束

Alter table table_name

Drop constraint constraint_name

在创建表时设置检查约束

Create table table_name(column_name datatype CHECK(expressions),..)

Constraint constraint_name CHECK(expressions)

在修改表时添加检查约束

Alter table table_name add constraint constraint_name check(expressions);

启用禁用检查约束

Select constraint_name,constraint_type,status from user_constraints where table_name=’table_name’;

Enable|disable constraint constraint_name

删除检查约束

Alter table table_name drop constraint constraint_name;

更改约束的名称

数据字典(user_constrains)

Alter table table_name

RENAME CONSTRAINT old_name TO new_name;

约束

主键约束 用来唯一表示一条数据的字段,其值不能重复,不能为null

create table test

(

nationality varchar2(20),

city varchar(20),

constraint nick_pk primary key(nationality,city)

);

外键约束 引用其他表的主键到本表,在本表中叫外键,用来做表关系

create table test

(

nationality varchar2(20),

city varchar(20),

constraint nick_fk foreign key(nationality) references

tab_name(nationality)

);

非空约束

create table test

(

nationality varchar2(20) not null,

);

唯一约束

create table test

(

nationality varchar2(20) ,

constraint nick_uk unique(nationality)

);

检查约束

create table test1

(

nationality varchar2(20) ,

constraint nick_ck check(nationality <> '美国')

);

默认值

default

设定约束条件无效

disable|enable constraint_name

级联删除<级联更新要使用触发器>

references … ON DELETE CASCADE

08Oracle Database 完整性约束的更多相关文章

  1. python全栈开发day54-mysql库操作、表操作、数据类型、完整性约束

    一.昨日内容回顾 1.mysql的安装 1).解压文件 添加环境变量bin 2).初始化mysql生成数据data文件夹: mysqld --initialize-insecure 3).mysqld ...

  2. PowerDesigner 参照完整性约束(转载)

    PowerDesigner 参照完整性约束: 限制(Restrict):不允许进行修改或删除操作.若修改或删除主表的主键时,如果子表中存在子记录,系统将产生一个错误提示.这是缺省的参照完整性设置. 置 ...

  3. python 全栈开发,Day61(库的操作,表的操作,数据类型,数据类型(2),完整性约束)

    昨日内容回顾 一.回顾 定义:mysql就是一个基于socket编写的C / S架构的软件 包含: ---服务端软件 - socket服务端 - 本地文件操作 - 解析指令(mysql语句) ---客 ...

  4. mysql三-3:完整性约束

    一.完整性约束介绍 约束条件与数据类型的宽度一样,都是可选参数 作用:用于保证数据的完整性和一致性主要分为: PRIMARY KEY (PK) 标识该字段为该表的主键,可以唯一的标识记录 FOREIG ...

  5. 数据库基本表创建 完整性约束 foreign Key

    理解以下几张表的内容,根据实际情况设计属性名.数据类型.及各种完整性约束(primary key.foreign key.not null.unique.check),用数据定义语言实现,然后设计实验 ...

  6. 数据库管理员(Database Administrator,简称DBA)基本知识:

    数据库管理员(Database Administrator,简称DBA)基本知识: 一.数据库基础 1. 数据抽象:物理抽象.概念抽象.视图级抽象,内模式.模式.外模式 2. SQL语言包括数据定义. ...

  7. mysql对库,表,数据类型的操作以及完整性约束

    一丶对库的操作 求救语法: help create database; 1.创建数据库 CREATE DATABASE 数据库名 charset utf8; 2.数据库的命名规则: 可以由字母.数字. ...

  8. easyui datagrid 禁止选中行 EF的增删改查(转载) C# 获取用户IP地址(转载) MVC EF 执行SQL语句(转载) 在EF中执行SQL语句(转载) EF中使用SQL语句或存储过程 .net MVC使用Session验证用户登录 PowerDesigner 参照完整性约束(转载)

    easyui datagrid 禁止选中行   没有找到可以直接禁止的属性,但是找到两个间接禁止的方式. 方式一: //onClickRow: function (rowIndex, rowData) ...

  9. 16Oracle Database 系统权限和对象权限

    Oracle Database 系统权限和对象权限 Oracle中的系统权限和对象权限 DCL 数据控制语言 -- 查看对象的权限 grant / revoke 查看登录用户 Show user 查看 ...

随机推荐

  1. 《深入理解Android 卷III》第四章 深入理解WindowManagerService

    <深入理解Android 卷III>即将公布,作者是张大伟.此书填补了深入理解Android Framework卷中的一个主要空白.即Android Framework中和UI相关的部分. ...

  2. [办公应用]如何将excel合并单元格分拆后每个单元格上仍保留数据?

    合并单元格虽然美观,但是无法进行排序.筛选等操作. 只有合并单元格拆分后才可以按常规进行统计.但是普通拆分后,excel仅保留合并单元格数据到区域左上角的单元格. 解决方案:选定多个合并单元格,应用本 ...

  3. Linux/Android——Input系统之InputReader (七)【转】

    本文转载自:http://blog.csdn.net/jscese/article/details/42739197 在前文Linux/Android——Input系统之frameworks层Inpu ...

  4. 动态更改Menu

    好像没有现成的api可能获取menu完美方法,只有在创建menu时,用全局的menuItem记下, 在需要修改时修改. 1)全局量: MenuItem  gMenuItem=NULL; 2)//创建菜 ...

  5. pyhon-----安装yaml踩过的坑以及正解

    之前在网上找了各种资料,cmd安装yaml,网上大部分写的都是pip install yaml 可是,执行完就变成Could not find a version that satisfies the ...

  6. Ubuntu下 VirtualBox的卸载和升级 (转载)

    转载:http://blog.csdn.net/li_hai/article/details/8164744 首先,在终端查看已经安装的VirtualBox的版本: $ dpkg -l 查看到版本号, ...

  7. 安装Git(转载)

    转自:http://www.liaoxuefeng.com/wiki/0013739516305929606dd18361248578c67b8067c8c017b000/00137396287703 ...

  8. Tomcat的jvm配置

    Tomcat本身不能直接在计算机上运行,需要依赖于操作系统和一个JAVA虚拟机.Tomcat的内存溢出本质就是JVM内存溢出,JAVA程序启动时JVM会分配一个初始内存和最大内存给程序.当程序需要的内 ...

  9. bzoj 2957: 楼房重建【线段树】

    总之就是找前面所有点的斜率都严格小于这个点的这样的点的个数 不管是询问还是修改都非常线段树啊,而且相当眼熟是不是和hotel有点像啊,大概就是区间内记一个len一个max,分别是当前区间答案和区间最大 ...

  10. bzoj 1691: [Usaco2007 Dec]挑剔的美食家【贪心+splay】

    高端贪心,好久没写splay调了好久-- 以下v为价格,w为鲜嫩度 把牛和草都按v排升序,扫草,首先把v小于等于当前草的牛都丢进splay,这样一来splay里全是可选的牛了,按w排序,然后贪心的为当 ...