一.涉及内容 1.理解触发器的概念.作用和类型. 2.练习触发器的创建和使用. 二.具体操作 (实验) 1.利用触发器对在scott.emp表上执行的DML操作进行安全性检查,只有scott用户登录数据库后才能向该表中执行DML操作.(第1题中,user是系统函数,返回当前用户.字符串中使用两个单引号表示一个单引号.) 要求:分别以system用户和scott用户对emp 表执行DML操作,试验触发器的运行效果. (1)在scott用户下创建触发器 语句: create or replace t…
当前关于12c的中文资料比较少,本人将关于DBA的一部分官方文档翻译为中文,很多地方为了帮助中国网友看懂文章,没有按照原文句式翻译,翻译不足之处难免,望多多指正. 2.1 安装Oracle数据库软件和创建数据库概览 本章节讲述如何安装Oracle数据库软件,和创建一个实例Oracle数据库. 如果你正在使用Oracle数据库先前的版本,想要安装一个更新版本的Oracle数据库软件,你可以使用新版本的Oracle数据库软件升级你现有的Oracle数据库. 本章节包含以下几部分: (1)安装Orac…
from:http://blog.csdn.net/zhanzhib/article/details/48729417 触发器的意思就是当我们对数据库对象(一般是表或视图)进行insert.update.delete操作的时候,这些操作会相应的触发一些事件的执行,通常要执行的事件被写成PL/SQL程序,那么这些数据库对象上的事件相关的程序就是触发器(trigger).Oracle数据库中,触发器分为before.after.instead of三种,其中before.after主要对于表操作,i…
最近在做性能测试时,由于要挂载空间数据,开发人员直接将所有业务表都挂到了Oracle数据库中.最近做了几次测试发现响应时间和吞吐量都不是很理想,进行一番分析后怀疑可能在Oracle中出现问题,因此再网上找了一下相关的监控程序,最终发现Spotlight,但是没有详细的说明(也有可能是我没找到),下面将我之前如何连接Oracle并进行监测的一些经验分享一下,如有瑕疵请各位指教. 首先Spotlight的安装和部署我就不多说了,我相信大家都是很聪明的,安装一下so easy. 这里我要说的是一定要安…
Oracle服务器主要由实例.数据库.程序全局区和前台进程组成,其中实例就是用来提供管理数据库的功能:数据库由数据库文件组成,用来存储系统数据:实例可以进一步划分为系统全局区(SGA)和后台进程(PMON.SMON等)两部分,其中SGA是所有用户进程共享的一块内存区域,使用操作系统的内存资源,而后台进程需要使用CPU与内存资源.数据库中包含数据文件.控制文件和重做控制文件,数据库存放在硬盘中.程序全局区(PGA)是一个非共享的内存区域,用于管理用户进程的私有资源.前台进程可以再划分为用户进程和服…
上文我们已经建立了名为orcl66的数据库. 想要在数据库中创建.修改用户需要我们以管理员权限登录到数据库中. 首先我们通过sqlplus命令登录连接数据库. 输入sqlplus命令--用户名: sys as sysdba (回车)--口令:(任意字符都可以登录) 登陆成功后就可以创建新用户了.(我们是以sys用户下DBA权限登入,可以根据需求对用户名.密码.权限等进行修改) 一.如何创建用户 语法[创建用户]: create user 用户名 identified by 口令[即密码]: 大家…
当我们需要用到触发器的时候,还是很方便,你会指定当我在操作某一事件时触发效果完成我所希望完成的事情:这就是触发器, 下面我给大家上一串代码,这是一个当我在操作删除事件操作时候,我希望把即将删除那条数据,保存备用的表中,下面直接看看Oracle数据库中怎么写这样的代码: create or replace trigger 触发器名字 before delete on 表名 referencing old as old new as new for each row begin insert int…
1.PLSQL编程 1.1概念和目的 PL/SQL(Procedure Language/SQL) PLSQL是Oracle对sql语言的过程化扩展 指在SQL命令语言中增加了过程处理语句(如分支.循环),使SQL语言具有过程处理能力 1.2程序结构 通过PLsqlDeveloper工具的Test Windows创建程序模版或者通过语句在SQLWindows编写 提示:PLSQL语言的大小是不区分的 PL/SQL可以分为三个部分:声明部分.可执行部分.异常处理部分 [declare]  --声明…
创建视图语句: CREATE [OR REPLACE] [FORCE|NOFORCE] VIEW view_name [(alias[, alias]...)] AS subquery [WITH CHECK OPTION [CONSTRAINT constraint]] [WITH READ ONLY] CREATE OR REPLACE VIEW new_V_a(视图名) AS SELECT  * FROM T_a(表名)    CREATE OR REPLACE VIEW new_V_a(…
SQL> --当我们对empnew执行删除操作之后,它就会出现一个提示信息,提示:这是删除操作!SQL> CREATE TRIGGER first_trigger 2 AFTER DELETE 3 ON empnew 4 BEGIN 5 DBMS_OUTPUT.put_line('这是删除的操作!'); 6 END; 7 /Trigger created SQL> SET SERVEROUTPUT ONSQL> DELETE FROM empnew WHERE empno = 77…