这些是最简单的,理解这些再去看其他的高深一点的吧.......

游标

oracle里面的游标分为四种情况,分别是LOOP循环,FOR循环,删除,更新

1.LOOP循环

检索EMP表。使用LOOP循环语句遍历游标,输出指定部门编号(比如10)的员工信息(empno,ename,sal,deptno)

--定义游标--
DECLARE CURSOR cursor_emp (dept_no NUMBER := 10)
IS SELECT * FROM emp WHERE deptno = dept_no;
--%ROWTYPE是这个表的行的类型,与%TYPE不同--
row_emp emp%ROWTYPE;
BEGIN
OPEN cursor_emp(10);
LOOP
--下面这两行是固定模式,把游标查到的信息插入row_emp里面--
FETCH cursor_emp INTO row_emp;
EXIT WHEN cursor_emp%NOTFOUND;
--这个是输出语句,||用来分隔--
DBMS_OUTPUT.PUT_LINE('当前检索第'||cursor_emp%ROWCOUNT|| '行:员工号--'||row_emp.empno|| ',姓名--'|| row_emp.ename|| ',工资--'|| row_emp.sal|| ',部门编号--'|| row_emp.deptno);
END LOOP;
CLOSE cursor_emp;
END; --上面我们写完了LOOP类型的游标,里面有输出语句是吧,我们要想执行那语句必须加行代码--
set serverout on

2.For循环

我们还是实现上面的功能,不过这次我们使用For循环。这里不同的地方在于,For循环没有开启游标!也没有关闭游标!也没有那两句固定的语句!

DECLARE CURSOR cursor_emp(dept_no NUMBER := 10)
IS SELECT * FROM emp WHERE deptno = dept_no;
BEGIN
FOR row_emp IN cursor_emp LOOP
DBMS_OUTPUT.PUT_LINE('员工号:'||row_emp.empno||',姓名:'||row_emp.ename || ',工资:'|| row_emp.sal|| ',部门编号:'|| row_emp.deptno);
END LOOP;
END;

3.更新

使用显示游标更新emp表数据,将工资低于4000元的员工工资增加100元      (更新和删除都多一句FOR UPDATE)

DECLARE CURSOR cursor_emp
IS SELECT sal FROM emp WHERE sal < 4000
--发现没?多了一个FOR UPDATE!--
FOR UPDATE;
--这里我们定义的是%type,这个呢就是某个表行类型的一个列的类型!看emp.sal!!--
v_sal emp.sal%TYPE;
--下面还是LOOP循环里面的套路--
BEGIN
OPEN cursor_emp;
LOOP
--LOOP里面的两大固定语句,套路.......--
FETCH cursor_emp INTO v_sal;
EXIT WHEN cursor_emp%NOTFOUND;
--update语句--
UPDATE emp SET sal=sal+100 WHERE CURRENT OF cursor_emp;
END LOOP;
CLOSE cursor_emp;
END;

4.删除

删除部门号为40的所有员工

DECLARE CURSOR cursor_emp
IS SELECT * from emp WHERE deptno =40
FOR UPDATE;
row_emp emp%ROWTYPE;
BEGIN
OPEN cursor_emp;
LOOP
FETCH cursor_emp INTO row_emp ;
EXIT WHEN cursor_emp%NOTFOUND;
DELETE from emp WHERE CURRENT OF cursor_emp;
END LOOP;
CLOSE cursor_emp;
END;

函数

定义RESULT()函数计算两个数值相除结果(商和余数),使用IN-OUT参数。运行,返回20/3的结果

--定义函数--
CREATE OR REPLACE FUNCTION result(num1 NUMBER, num2 IN OUT NUMBER)
RETURN NUMBER
AS
v_result NUMBER(6);
v_remainder NUMBER;
BEGIN
v_result := FLOOR(num1 / num2);
v_remainder := MOD(num1, num2);
num2 := v_remainder;
RETURN v_result;
EXCEPTION
WHEN ZERO_DIVIDE THEN
DBMS_OUTPUT.PUT_LINE('错误信息:不能除0');
END;
--调用函数--
DECLARE
result1 NUMBER;
result2 NUMBER;
BEGIN
result2 := 3;
result1 := result(20,result2);
DBMS_OUTPUT.PUT_LINE('商是:'||result1);
DBMS_OUTPUT.PUT_LINE('余数是:'||result2);
END;

触发器

创建BEFORE触发器trig_OutPutScore,更新scores分数时显示分数变化(原来分数##,现在分数##)

CREATE OR REPLACE TRIGGER trig_OutPutScore
BEFORE UPDATE ON scores
FOR EACH ROW --每更新一行就会触发一次--
DECLARE
oldvalue NUMBER;
newvalue NUMBER;
BEGIN
oldvalue := :OLD.sscore; --更新之前的sscore的值--
newvalue := :NEW.sscore; --更新之后的sscore的值--
DBMS_OUTPUT.PUT_LINE('原来分数='||oldvalue|| ',现在分数='||newvalue);
END;

调用触发器

update scores set sscore=sscore+5;

存储过程

创建存储过程

CREATE OR REPLACE PROCEDURE proc_GetScoresBySno (no IN NUMBER, result OUT NUMBER)
AS
BEGIN
SELECT SUM(sscore) INTO result FROM scores WHERE sno = no;
END;

调用存储过程

--variable是定义全局变量的意思--
VARIABLE AllScores NUMBER;
EXEC proc_GetScoresBySno(201102,:AllScores);
PRINT AllScores;

Oracle 重要知识点的更多相关文章

  1. 【体系结构】有关Oracle SCN知识点的整理

    [体系结构]有关Oracle SCN知识点的整理 1  BLOG文档结构图   BLOG_Oracle_lhr_Oracle SCN的一点研究.pdf 2  前言部分 2.1  导读和注意事项 各位技 ...

  2. oracle 数据库——知识点总结(加示例)

    新入oracle数据库,把目前学到的知识点记录下来,可能都比较基础,但还是比较全的,里面的示例都是自己在PL/SQL中跑过的,如果有错误,还望各位大侠指出哈. 创建用户 1.创建用户(使用管理员身份创 ...

  3. 数据从mysql迁移至oracle时知识点记录(一)

    最近在做数据的迁移,再将数据从mysql迁移至oracle时,部分sql语句进行了修改,在此对部分知识点进行记录: 参考资料:https://dev.mysql.com/doc/refman/5.5/ ...

  4. Oracle 相关知识点结构图

    最近在学Oracle数据库,制作了些结构图方便记忆!主要涉及到Oracle数据类型,Oracle的表操作以及Oracle的游标,还有的之后再分享...... Oracle 数据类型 因为图片上只能看到 ...

  5. oracle数据库知识点

    1.oracle启动后的服务 1. Oracle ORCL VSS Writer Service:Oracle卷映射拷贝写入服务,VSS(Volume Shadow Copy Service)能够让存 ...

  6. oracle的知识点总结

    体系结构:数据库的体系结构是指数据库的组成.工作过程与原理,以及数据在数据库中的组织与管理机制.体系结构包括:实例(instence),数据库文件(database),用户进程(user proces ...

  7. Oracle基础知识点——Oracle服务端和客户端

    Oracle服务端 服务端提供oracle服务的实例,其是数据库的核心,用于数据库的管理,对象的管理与存储.数据的存储.查询.数据库资源的监控.监听等一些服务. 例子:比如一台机子上安装了Oracle ...

  8. oracle小知识点

    一 . procedure和function: procedure和function在语法上几乎完全一样,使用上却有小小的差别, procedure可以单独的调用 在命令行直接exec pro_xxx ...

  9. oracle 基本知识点

    //创建临时表空间create temporary tablespace test_temp tempfile 'E:\oracle\product\10.2.0\oradata\testserver ...

随机推荐

  1. xml中该使用属性还是元素

    XML 中没有规定哪些必须放在属性或者子元素,因此使用哪种方式都是可以实现的.这取决于个人的经验和喜好.在可以使用元素也可以使用属性的两选一的情况下,个人更倾向于使用子元素.主要理由如下: 1. 属性 ...

  2. REST-framework快速构建API--认证

    一.API使用流程 使用过API的同学都知道,我们不可能任意调用人家的API,因为通过API可以获取很多关键数据,而且这个API可能供多个部门或个人使用,所以必须是经过授权的用户才能调用. API的使 ...

  3. 浅谈SVG(可缩放的矢量图形)

    前一段项目中用到了svg图片就和其他的元素一样 直接引用就可以展示在页面上,因为项目紧张没有仔细的研究,最近在扩展自己的基础知识,偶然看到了这个东西,于是总结了一些博客园中关于这个svg的基础知识,只 ...

  4. python基础面试题

    函数1def foo(arg,li=[]): li.append(arg) return li list1 = foo(21) list2 = foo(11,[2]) list3 = foo(28) ...

  5. Java 面向对象之构造方法

    01构造方法引入 A:构造方法的引入 在开发中经常需要在创建对象的同时明确对象的属性值,比如员工入职公司就要明确他的姓名.年龄等属性信息. 那么,创建对象就要明确属性值,那怎么解决呢?也就是在创建对象 ...

  6. PowerDesigner数据库设计实用技巧

    欢迎大家补充,谢谢! 1. 原始单据与实体之间的关系 可以是一对一.一对多.多对多的关系.在一般情况下,它们是一对一的关系:即一张原始单据对应且只对应一个实体.在特殊情况下,它们可能是一对多或多对一的 ...

  7. float和position的使用

    http://blog.csdn.net/yaodebian/article/details/58621183

  8. Scrum Meeting NO.5

    Scrum Meeting No.5 1.会议内容 暂时料理完了编译,可以写软工了.说多了都是泪T_T 2.任务清单 徐越 序号 近期的任务 进行中 已完成 1 修改url名.参数 √ 2 学习Jso ...

  9. 《Linux内核设计与实现》第5章读书整理

                                 <第五章 系统调用>笔记 5.1 与内核通信 系统调用在用户空间和硬件设备之间提供了一个中间层. 中间层的作用: 为用户空间提供一 ...

  10. 『编程题全队』Alpha 阶段冲刺博客Day6

    1.每日站立式会议 1.会议照片 2.昨天已完成的工作统计 孙志威: 1.添加JSON处理模块 2.添加了团队看板中的添加团队任务功能 3.添加了团队看板中的添加按钮 孙慧君: 1.个人任务框UI的设 ...