目标

通过本章学习,您将可以:

l  使用 DML 语句

l  向表中插入数据

l  更新表中数据

l  从表中删除数据

l  控制事务

l  描述约束

l  创建和维护约束

数据控制语言

l     DML(Data Manipulation Language – 数据操作语言) 可以在下列条件下执行:

  • 向表中插入数据
  • 修改现存数据
  • 删除现存数据

l  事务是由完成若干项工作的DML语句组成的

从其它表中拷贝数据

INSERT INTO sales_reps(id, name, salary, commission_pct)

SELECT employee_id, last_name, salary, commission_pct

FROM   employees

WHERE  job_id LIKE '%REP%';

数据库事务

数据库事务由以下的部分组成:

l  一个或多个DML 语句

l  一个 DDL(Data Definition Language – 数据定义语言) 语句

l  一个 DCL(Data Control Language – 数据控制语言) 语句

l  以第一个 DML 语句的执行作为开始

l  以下面的其中之一作为结束:

l  COMMIT 或 ROLLBACK 语句

l  DDL 或 DCL 语句(自动提交)

l  用户会话正常结束

l  系统异常终了

控制事务

l     使用 SAVEPOINT 语句在当前事务中创建保存点。

l  使用 ROLLBACK TO SAVEPOINT 语句回滚到创建的保存点。

UPDATE...

SAVEPOINT update_done;

INSERT...

ROLLBACK TO update_done;

如果直接ROLLBACK将会全部回滚

什么是约束

l   约束是表级的强制规定

l   有以下五种约束:

  • • NOT NULL
  • • UNIQUE
  • • PRIMARY KEY
  • • FOREIGN KEY
  • • CHECK

l   如果不指定约束名 Oracle server 自动按照 SYS_Cn 的格式指定约束名

NOT NULL 约束

CREATE TABLE employees(

employee_id    NUMBER(6),

last_name      VARCHAR2(25) NOT NULL,//系统约束命名

salary         NUMBER(8,2),

commission_pct NUMBER(2,2),

hire_date      DATE

CONSTRAINT emp_hire_date_nn//自定义约束命名

NOT NULL,

UNIQUE 约束

CREATE TABLE employees(

employee_id      NUMBER(6),

last_name        VARCHAR2(25) NOT NULL,

email            VARCHAR2(25) ,

salary           NUMBER(8,2),

commission_pct   NUMBER(2,2),

hire_date        DATE NOT NULL,

...

CONSTRAINT emp_email_uk UNIQUE(email));

PRIMARY KEY 约束

CREATE TABLE   departments(

department_id        NUMBER(4),

department_name      VARCHAR2(30)

CONSTRAINT dept_name_nn NOT NULL,

manager_id           NUMBER(6),

location_id          NUMBER(4),

CONSTRAINT dept_id_pk PRIMARY KEY(department_id));

FOREIGN KEY 约束

CREATE TABLE employees(

employee_id      NUMBER(6),

last_name        VARCHAR2(25) NOT NULL,

email            VARCHAR2(25),

salary           NUMBER(8,2),

commission_pct   NUMBER(2,2),

hire_date        DATE NOT NULL,

...

department_id    NUMBER(4),

CONSTRAINT emp_dept_fk FOREIGN KEY (department_id)

REFERENCES departments(department_id),

CONSTRAINT emp_email_uk UNIQUE(email));

FOREIGN KEY 约束的关键字

  • •          FOREIGN KEY: 在表级指定子表中的列
  • • REFERENCES: 标示在父表中的列
  • • ON DELETE CASCADE: 当父表中的列被删除时,子表中相对应的列也被删除
  • • ON DELETE SET NULL: 当父表中的列被删除时,子表中相应的列置空

CHECK 约束

..., salary NUMBER(2)

CONSTRAINT emp_salary_min

CHECK (salary > 0),...

添加约束的语法

使用 ALTER TABLE 语句:

l  添加或删除约束, 但是不能修改约束

l  有效化或无效化约束

l  添加 NOT NULL 约束要使用 MODIFY 语句

ALTER TABLE         table

ADD [CONSTRAINT constraint] type (column);

ALTER TABLE     employees

ADD CONSTRAINT  emp_manager_fk

FOREIGN KEY(manager_id)

REFERENCES employees(employee_id);

删除约束

ALTER TABLE      employees

DROP CONSTRAINT  emp_manager_fk;

oracle 10g 学习之数据进行增删改查、数据库事务、约束(8)的更多相关文章

  1. Mybatis学习总结(二)—使用接口实现数据的增删改查

    在这一篇中,让我们使用接口来实现一个用户数据的增删改查. 完成后的项目结构如下图所示: 在这里,person代表了一个用户的实体类.在该类中,描述了相关的信息,包括id.name.age.id_num ...

  2. Delphi - cxGrid连接Oracle数据库 实现数据的增删改查

    cxGrid连接Oracle数据库 实现数据的增删改查 cxGrid连接Oracle数据库 1:通过OraSession连接数据库.OraDataSet实现OraSession和OraDataSour ...

  3. django学习-12.访问不同url/接口地址实现对指定数据的增删改查功能

    1.前言 通过前面博客[django学习-10.django连接mysql数据库和创建数据表]里的操作,我们已经成功在数据库[hongjingsheng_project]里创建了一张数据表[hello ...

  4. mysql学习笔记一 —— 数据的增删改查

    1.连接mysql mysql 直接回车(是以root身份,密码空,登陆的是本机localhost) [root@www mysql]# mysql -uroot -p123 -S /var/lib/ ...

  5. python学习之-成员信息增删改查

    python学习之-成员信息增删改查 主要实现了成员信息的增加,修改,查询,和删除功能,写着玩玩,在写的过程中,遇到的问题,旧新成员信息数据的合并,手机号和邮箱的验证,#!/usr/bin/env p ...

  6. EF学习笔记-1 EF增删改查

    首次接触Entity FrameWork,就感觉非常棒.它节省了我们以前写SQL语句的过程,同时也让我们更加的理解面向对象的编程思想.最近学习了EF的增删改查的过程,下面给大家分享使用EF对增删改查时 ...

  7. vue实现对数据的增删改查(CURD)

    vue实现对数据的增删改查(CURD) 导语: 网上看到一个写的比较好的学习文章,转载分享一下 在管理员的一些后台页面里,个人中心里的数据列表里,都会有对这些数据进行增删改查的操作.比如在管理员后台的 ...

  8. Mybatis框架基于注解的方式,实对数据现增删改查

    编写Mybatis代码,与spring不一样,不需要导入插件,只需导入架包即可: 在lib下 导入mybatis架包:mybatis-3.1.1.jarmysql驱动架包:mysql-connecto ...

  9. dbutils中实现数据的增删改查的方法,反射常用的方法,绝对路径的写法(杂记)

    jsp的三个指令为:page,include,taglib... 建立一个jsp文件,建立起绝对路径,使用时,其他jsp文件导入即可 导入方法:<%@ include file="/c ...

随机推荐

  1. PHP高效率写法(详解原因)

    1.尽量静态化: 如果一个方法能被静态,那就声明它为静态的,速度可提高1/4,甚至我测试的时候,这个提高了近三倍.当然了,这个测试方法需要在十万级以上次执行,效果才明显.其实静态方法和非静态方法的效率 ...

  2. Why The Golden Age Of Machine Learning is Just Beginning

    Why The Golden Age Of Machine Learning is Just Beginning Even though the buzz around neural networks ...

  3. URLDecoder与URLEncoder

    网页中的表单使用POST方法提交时,数据内容的类型是 application/x-www-form-urlencoded,这种类型会: 1.字符"a"-"z", ...

  4. pthread多线程编程的学习小结

    pthread多线程编程的学习小结  pthread 同步3种方法: 1 mutex 2 条件变量 3 读写锁:支持多个线程同时读,或者一个线程写     程序员必上的开发者服务平台 —— DevSt ...

  5. Oracle 10g 和11g r2 下载地址(使用迅雷)

    http://www.blogjava.net/wangdetian168/archive/2011/03/01/345428.html  10g http://www.blogjava.net/wa ...

  6. cad2013

    ## ribbon界面? ribbon界面是一种设计ui, 可以认为是传统的  菜单和工具栏  组合. 是 用于 实时显示 + 面向结果的 设计ui 但并不是所有的程序都适合.  ribbon 并不是 ...

  7. C#集合实现接口一览表

  8. Oulipo (kmp)

    Oulipo Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 26857   Accepted: 10709 Descript ...

  9. back(返回)键总结

    对于一般的android手机,都提供了四个(目前主流三个)按键.这几个按键中,back(返回)键用得比较多,对back键出发的事件一般是通过重写onKeyDown(int keyCode, KeyEv ...

  10. linux 文件权限除了r、w、x外还有s、t、i、a权限:

    s:文件属主和组设置SUID和GUID,文件在被设置了s权限后将以root身份执行.在设置s权限时文件属主.属组必须先设置相应的x权限,否 则s权限并不能正真生效(c h m o d命令不进行必要的完 ...