主键约束;外键约束;唯一性约束;检查约束;默认值约束 -——————五大约束

一、 主键约束;

--创建表的主键约束
  create table student (student_id number primary key,student_name varchar2(20),sudent_birthday date,student_address varchar2(50),student_phone varchar2(20))

--显示命名主键约束
  --第一种写法:create table student1 (student_id number  constraint pk_student primary key ,student_name varchar2(20),sudent_birthday date,student_address varchar2(50),student_phone varchar2(20))
 第二种写法: create table student1 (student_id number   ,student_name varchar2(20),sudent_birthday date,student_address varchar2(50),student_phone varchar2(20) constraint pk_student primary key(student_id))
 --创建多列主键

create table student1 (student_id number   ,student_name varchar2(20),sudent_birthday date,student_address varchar2(50),student_phone varchar2(20) constraint pk_student primary key(student_id,student_name))
  --查看用户创建的所有约束
  select * from user_constraints where table_name like '%STUD%'

 --创建无主键的表
   create table student2 (student_id number ,student_name varchar2(20),sudent_birthday date,student_address varchar2(50),student_phone varchar2(20))
--为新建的表添加 主键约束
  alter table student2 modify (student_id number primary key )
    --创建无主键的表
   create table student3 (student_id number ,student_name varchar2(20),sudent_birthday date,student_address varchar2(50),student_phone varchar2(20))
  --为表添加多列主键
 alter table student3 add constraint pk_studentForMutPrimarykey primary key (student_name,sudent_birthday,student_address)
 --删除主键 与列一样,主键是表的一个对象,删除表的主键与删除列的语法非常相似。
alter table student3 drop primary key
--当然,如果将主键看做表的一 个对象,而且知道主键的名称,那么可以利用删除约束的语法来删除表的主键。如下:
alter table student3 drop constraint pk_studentForMutPrimarykey

--启用/禁用主键
alter table student disable primary key ;
alter table student enable primary key ;

--重命名主键
alter table student3 rename constraint pk_studentForMutPrimarykey to PK_STUDENT2

主键的应用场景
1. 对于完整性要求比较高的数据表都应该建立主键
2.对于经常按照某列进行查询的数据表,应该考虑建立主键
3.考虑是否对外键有利

二、外键约束;

--创建表customers
create table customers (customer_id number primary key ,customer_name varchar2(50),customer_address varchar2(50),customer_phone varchar2(30),email varchar2(20),constrator varchar2(20));
--创建表orders
create table orders (order_id number primary key ,customer_id number,goods_name varchar(20),quantity number,unit varchar(10));
--创建外键约束
alter table orders add constraint fk_orders_customers foreign key (customer_id) references customers(customer_id)

--重命名外键
alter table orders rename constraint FK_ORDERS_CUSTOMERS to FK_ORDERS
--启用/禁用外键
alter table orders modify constraint FK_ORDERS disable
alter table orders modify constraint FK_ORDERS enable

--删除外键
alter table orders drop constaint FK_ORDERS

三、唯一性约束;

--创建唯一性约束
create table users(user_id number primary key ,
user_name varchar2(50),user_address varchar2(50),user_phone varchar2(20),
email varchar2(20) unique,constractor varchar2(20))
--将表的某一列设置为 :唯一性约束:
 alter table users add constraint uq_phone unique (user_phone)
 --查看唯一性约束
 select * from user_constraints where table_name='USERS'
 select * from user_cons_columns where table_name='USERS'
--删除唯一性约束
 alter table users drop constraint uq_phone

四、检查约束;

--创建检查约束
create table students (student_id number primary key ,student_name varchar2(10),
subject varchar2(20),score number constraint chk_score check(score between 0 and 100))

--复杂些的检查约束

create table employees(
                           employee_id number primary key ,employee_name varchar2(10),grade varchar2(10),salary number,constraint chk_salary
                           check(
                                       grade in('MANAGER','LENDER','STAFF') --grade 为'MANAGER','LENDER','STAFF' 这三个中一个
                                       and
                                            (
                                                       grade='MANAGER' and salary<=8000    --若grade 为grade='MANAGER' and salary<=8000
                                                       or grade='LERDER' and salary<=5000   --若grade 为grade='LERDER' and salary<=5000
                                                       or grade='STAFF' and salary<=4000     --若grade='STAFF' and salary<=4000
                                             )
                                  )
                         )

--添加检查约束:
alter table employees add constraint chk_name check(length(employee_name)<=4)
--删除检查约束
alter table employees drop constraint chk_name

--重命名检查约束
 alter table employees rename constraint chk_salary to chk_grade_salary
--禁用/启用检查约束
--禁用
alter table employees disable constraint chk_grade_salary
alter table employees modify constraint chk_grade_salary disable

--启用
alter table employees enable constraint chk_grade_salary
alter table employees modify constraint chk_grade_salary enable

五、默认值约束

默认值约束也是数据库中的常用约束。当向数据表中插入数据时,并不总是将所有字段一一插入。对于某些特殊字段,其值是固定或相似的。用户希望,如果没有显式指定值,就使用某个特定的值进行插入,即默认值。为列指定默认值的操作即为设置默认值约束。
  默认值约束简介
         就像前面所述,数据表的列可以有非空约束,所以如果允许列的值为非空的,对于某个字段值不进行显式赋值是允许的。但是,同样可以对其设定默认值约束,一旦设定默认值约束,该列将使用默认值赋值作为空值的替代值。即使未为列指定默认值,那么oracle将隐式使用Null作为默认值,即default null 在oracle 9i以前的版本,用户使用默认值只能使用常量值;而oracle9i 及以后版本,用户将可以使用sysdate等函数来对列指定默认值。

--创建默认值约束
create table purchase_order(purchase_order_id number,goods_name varchar(30),quantity number, price number, status varchar2(3) default 'ACT')

--插入一条测试数据
insert into purchase_order(purchase_order_id,goods_name,quantity,price) values
(1,'Sweater',100,62)
--查询查看默认值
select * from purchase_order

--使用函数作为默认值
  create table sales (id number primary key ,product_name varchar2(20),price number, quantity number,total number, sales_date date default sysdate)
--插入数据 测试默认 值的存在性
insert into sales (id,product_name,price, quantity, total) values (1,'SWEATER',20,1,12);
insert into sales (id,product_name,price, quantity,total) values(2,'T-SHIRT',38,3,114);
select * from sales

--修改默认值约束
 alter table sales modify quantity number default 1

--向表中插入数据查看默认值有没有 启作用
 insert into sales (id,product_name,price)values(3,'SWEATER',20);
insert into sales (id,product_name,price)values(4,'孙业宝',39);
select * from sales;

--删除默认值约束

alter table sales modify quantity number default null
   insert into sales (id,product_name,price)values(5,'SWEATER',20);
insert into sales (id,product_name,price)values(6,'孙业宝',39);
select * from sales;

运行结果:

oracle学习系列之三 (约束)的更多相关文章

  1. Oracle学习系列1-7

    Oracle学习系列1 两个服务必须启动: OracleOraDb10g*TNListener 和 OracleService*** 使用sqlplusw先进行环境的设置 set linesize 3 ...

  2. Oracle学习系列7

    Oracle学习系列7 ************************************************************************************ 关联表 ...

  3. Oracle学习系列6

    Oracle学习系列6 ************************************************************************************ 删除约 ...

  4. Oracle学习系列5

    Oracle学习系列5 ************************************************************************************ ,掌握 ...

  5. Oracle学习系列4

    Oracle学习系列4 ************************************************************************************ 数据库 ...

  6. Oracle学习系列3

    Oracle学习系列3 ************************************************************************************ 多表查 ...

  7. CAN总线学习系列之三——CAN控制器的选择

    CAN总线学习系列之三——CAN控制器的选择 在进行CAN总线开发前,首先要选择好CAN总线控制器.下面就比较一些控制器的特点. 一些主要的CAN总线器件产品 制造商 产品型号 器件功能及特点 Int ...

  8. SQL Sever 学习系列之三

    SQL Sever 学习系列之三 SQL Server 学习系列之一(薪酬方案+基础) SQL Server 学习系列之二(日期格式问题)         五.经理今天刚谈到with的用法(with的 ...

  9. 大数据学习系列之三 ----- HBase Java Api 图文详解

    版权声明: 作者:虚无境 博客园出处:http://www.cnblogs.com/xuwujing CSDN出处:http://blog.csdn.net/qazwsxpcm 个人博客出处:http ...

随机推荐

  1. Mongodb集群搭建及spring和java连接配置记录

    一.基本环境: mongdb3.0.5数据库 spring-data-mongodb-1.7.2.jar mongo-java-driver-3.0.2.jar linux-redhat6.3 tom ...

  2. 1.html5 学习要求,Html 5发展历程

    以下是我在学习html5,项目中用到的关于html5的总结和心得. 1.学习要求 Html4.01,xhtml Css2 Javascript 耐心,动手,毅力. 2.Html 发展历程 Html1. ...

  3. 网页爬虫--scrapy入门

    本篇从实际出发,展示如何用网页爬虫.并介绍一个流行的爬虫框架~ 1. 网页爬虫的过程 所谓网页爬虫,就是模拟浏览器的行为访问网站,从而获得网页信息的程序.正因为是程序,所以获得网页的速度可以轻易超过单 ...

  4. Topology的构建

    public class BlackListBolt extends BaseRichBolt{ private static Logger logger = Logger.getLogger(Bla ...

  5. alpha融合

    //alpha融合 //作者:sandy //时间:2015-10-6 //将一只狗的头像融合在蜗牛头上 #include <cv.h> #include <highgui.h> ...

  6. 自己动手写ORM

    http://blog.csdn.net/sundacheng1989/article/category/1350100

  7. unity c#

    gameObject //获取当前脚本挂载到的游戏对象 在Unity中就算使用了C#进行编写脚本,要输出时不能使用Console类,应当使用print();或者Debug.log(); transfo ...

  8. 建立dblink

    源地址:http://blog.itpub.net/24104981/viewspace-1116085/ create database link dblinkname connect to use ...

  9. C API 连接MYSQL

    #include <iostream> #include <mysql.h> #include <string> #include <assert.h> ...

  10. 《一课经济学》书摘笔记III

    基本谬论:世界上可做的工作是有限的.用更有效率的方式去做事,只会消减工作机会.这个信条换句话说就是,采用低效率的方式去做一件事,反而可以创造工作机会. 只要还有人的需要或愿望还没有获得满足,能做的事就 ...