约束类型

1、主键primary key(一般是一个表的标志,所以一个表只能有一个主键;主键不能为空,不能重复)

2、唯一键unique(不能重复)

3、外键foreign key

4、检查约束check(not null不能为空;default默认值)

建表的同时添加约束

create table person(

  pid number(18) primary key,              --primary key主键,不能为空,不能重复

  name varchar2(50) unique not null,           --unique唯一约束,不能重复,可以为空;not null不能为空

  sex varchar2(4) default '男' check(sex in('男','女')),    --性别必须是男或女,default默认为男

  age number(3) check(age>0 and age<=120)       --年龄数据类型为3位,check里条件规定了范围

)

后期添加(约束表已经建立好不能删除)

添加约束

  修改表  表名  添加  约束  起名字  约束类型  列名

  alter table 表名 add constraint 起名字 约束类型  (列名);

添加主键

alter table 表名 add constraint 起名字 primary key (列名);

如:alter table student add constraint pk_sid primary key (sid);

添加唯一约束

alter table 表名 add constraint 起名字 unique (列名);

如:alter table student add constraint uq_name unique (name);

添加检查约束

alter table 表名 add constraint 起名字 check(条件);

如:alter table student add constraint ck_sex check(sex in('男','女'));

添加默认值(modify修改)

alter table 表名 modify 列名 default '女';

如:alter table student modify sex default '女';

修改表的字段类型(modify修改)

alter  table 表名 modify 列名 数据类型;

如:alter  table student modify sex varchar2(5);

如:alter table student modify name not null;

修改表结构

alter table 表名

modify 列名 数据类型

modify 列名 default 'something'

如:alter table studentinfo

  modify stuname varchar(20)

  modify stusex default '男'

建表时添加外键

如:create table student(

    cid number(12) references myclass  --myclass是另一个表名

  )

后期添加外键约束

alter table 表名 add constraint 起名字 foreign key (列名) references 表名;

如:alter table student add constraint fk_cid foreign key (cid) references myclass

删除约束

alter table 表名 drop constraint 约束名称

找约束名称

select * from user_constraints where table_name='表名'

如:select * from user_constraints where table_name='student'

回滚(oracle数据库 默认添加的数据是需要提交的 ,不提交其它的人看不到)

(刚添加修改删除的数据没有保存到数据库,只是临时的)

commit;         --提交 永久的的保存到数据库了

rollback table 表名 ;  --回退没提交之前的数据

truncate table  表名;  --表截断,立刻清除表里面的所有数据并且不能回滚

SQL结构化查询语言

1、DDL数据定义语言  不能回滚

  create,alter,drop

2、DML数据操作语言  可以回滚

  insert,delete,update,select

3、DCL数据控制语言  权限

  grant,revoke

4、TCL事务控制语言

  commit,rollback

数据移植:导入导出.dmp,在cmd中执行命令

关于oracle数据库(6)约束的更多相关文章

  1. 改写了禁用或启用oracle数据库的约束的存储过程

    改写了网上某位大侠(最开始的源头是哪位没记住)写的禁用或启用oracle数据库所有约束的存储过程,增加了异常控制,以使发生异常时也可以执行下去. –调用过程: 执行前先 set serveroutpu ...

  2. Oracle数据库添加约束

    主键约束(两个特性)1:主键必须写2:主键不可重复 create table stu01( sid varchar(100), sname varchar2(100) --constraint PK_ ...

  3. oracle数据库 唯一约束的创建与删除

    1.创建索引: alter table TVEHICLE add constraint CHECK_ONLY unique (CNUMBERPLATE, CVIN, CPLATETYPE, DWQCH ...

  4. oracle数据库中提供的5种约束

    约束作用:用来保持数据的完整性,防止无效数据进入到数据库中.oracle数据库中提供的5种约束,都是限定某个列或者列的组合的.1.主键约束(PRIMARY KEY):在一个表中能唯一的标识一行.主键可 ...

  5. Oracle数据库五种约束

    oracle 数据库 数据表的5个约束类型:1.主键约束2.外键约束3.唯一约束4.检查约束5.非空约束 主键约束:用来唯一标示表中的一个列,一个表中的主键约束只能有一个,但是可以在一个主键约束中包含 ...

  6. Oracle数据库创建表是有两个约束带有默认索引

    Oracle数据库创建表是有两个约束带有默认索引.1.主键primary Key:唯一索引.非空2.唯一Unique:唯一索引,可以是空值如果没有设定主键和唯一约束,表中不会有默认索引的. 建立主键/ ...

  7. Oracle 数据库表中已有重复数据添加唯一键(唯一约束)

    Oracle 数据库表中已有重复数据添加唯一键(唯一约束) 问题描述 以 demo 举例,模拟真实场景. 表 TEST_TABLE 有如下字段和数据:id 是主键,code 没有设置键和索引 ID C ...

  8. Oracle数据库中违反唯一约束的处理

    根据NULL的定义,NULL表示的是未知,因此两个NULL比较的结果既不相等,也不不等,结果仍然是未知.根据这个定义,多个NULL值的存在应该不违反唯一约束. 实际上Oracle也是如此实现的: SQ ...

  9. Oracle 数据库语句大全

    Oracle数据库语句大全 ORACLE支持五种类型的完整性约束 NOT NULL (非空)--防止NULL值进入指定的列,在单列基础上定义,默认情况下,ORACLE允许在任何列中有NULL值. CH ...

随机推荐

  1. js数组操作-打乱数组

    <style> html, body { margin: 0; padding: 0;} div span { display: inline-block; width: 25px; he ...

  2. 【hihoCoder 1466】后缀自动机六·重复旋律9

    http://hihocoder.com/problemset/problem/1466 建出A串和B串的两个后缀自动机 对后缀自动机的每个状态求出sg值. 求出B串的\(sum(x)\),表示B有多 ...

  3. 关于ajax的短轮询问题

    利用前台的ajax不断向后台服务器请求,后台服务器不断查看数据库里的信息是否变化.若变化将信息返回前台,并执行一些操作 前台ajax代码 注意要加上cache这一项,如果是post请求的化,可以免了. ...

  4. CF Round #353 Div.2

    http://codeforces.com/contest/675 A. Infinite Sequence 题意:给出等差数列的首项a以及公差c,问数b是不是该数列中的数,若是输出YES否则输出NO ...

  5. 3.struts2访问Servlet API,并和mybaits实现全套增删改查

    1.创建数据库脚本userinfo.sql prompt PL/SQL Developer import file prompt Created on 2016年5月19日 by pc set fee ...

  6. 四大高质量且实用的chrome翻译插件推荐

    Google英译汉的质量怎么样?日常生活用语翻译还可以,但是一到专业性术语就歇菜了,翻译出来的东西简直就是惨不忍睹,惨绝人寰..对于酷爱英语学习又有强迫症的患者来说,一款既实用又方便,无疑就是雪中送炭 ...

  7. [SOJ] 畅通工程续

    Description 某省自从实行了很多年的畅通工程计划后,终于修建了很多路.不过路多了也不好,每次要从一个城镇到另一个城镇时,都有许多种道路方案可以选择,而某些方案要比另一些方案行走的距离要短很多 ...

  8. Spring mail 邮件发送的简单实现

    package cn.taskSys.utils; import java.util.Properties; import org.springframework.mail.MailException ...

  9. Debian系Linux的dpkg命令

    dpkg "是"Debian Packager "的简写.为 "Debian" 专门开发的套件管理系统,方便软件的安装.更新及移除.所有源自" ...

  10. 下载PhpStorm并进行激活

    1.首先登陆PhpStorm官网http://www.jetbrains.com/phpstorm/ 点击附图中的download now 按钮 2.第二步根据os x \wind\ linux进行下 ...