1、              Oracle的自定义函数

2、              Oracle的触发器

3、              Oracle的存储过程

知识点一:自定义函数

语法:create [or replace] function 函数名(参数)

return返回值类型—必须

is

--变量的声明

begin

--执行语句

--return 返回变量

--exception 异常块(return 异常编号)

end;

Java:

int add(int no1,int no2)

{

int sum = no1+no2;

return sum;

}

Oracle

--编写一个简单的自定义函数

createorreplacefunction fun_add(no1 number,no2 number)

returnnumber

is

v_sum number;

begin

v_sum := no1+no2;

return v_sum;

exception

whenothersthen

return-1;

end;

调用函数

方式一:

select fun_add(50,50) from dual;

方式二:

declare

v_no1 number(2);

v_no2 number(2);

v_sum number(3);

begin

v_no1 :=50;

v_no2 :=50;

v_sum := fun_add(v_no1,v_no2);

if v_sum =-1then

dbms_output.put_line('输入的数据有误!');

else

dbms_output.put_line(v_sum);

endif;

exception

whenothersthen

dbms_output.put_line('输入的数据有误!');

end;

知识点二:触发器 trigger(DML触发器)

语法:

create[or replace]  trigger tri_名字

after|before

insert|delete|update

on 表名

[for each row]—行级触发器

begin

--执行语句块

end;

案例:删除emp表数据的时候,让emp_bak表自动备份

--删除emp_bak表数据的时候,让emp_bak01表自动备份

createorreplacetrigger  tri_delemp

afterdelete

on emp_bak

foreachrow

begin

insertinto emp_bak01(empno,ename,job,mgr,hiredate,sal,comm,deptno)

values(:old.empno,:old.ename,:old.job,:old.mgr,:old.hiredate,:old.sal,

:old.comm,:old.deptno);

end;

案例:创建userinfo(userid,uname,upw),userid自动+1实现

步骤一:创建一个表

createtable userinfo(

userid number(4) primary key,

uname varchar2(10)notnullunique,

upw varchar2(10)notnull

)

步骤二:创建序列

create sequence seq_userid;

步骤三:创建触发器

createorreplacetrigger tri_userid

beforeinsert

on userinfo

foreachrow

begin

select seq_userid.nextval into:new.userid from dual;

end;

步骤四:启动触发器

insert into userinfo(uname,upw) values('lily','123456');

案例:实现更改userinfo表的名字这个字段的时候,对原来数据进行备份,备份到userinfo_bak表中

知识点三:存储过程procedure

语法:

create or replace procedure pro_存储过程名称(输入参数 in,输出参数 out)

as

--变量的声明

begin

--执行过程

--exception异常处理过程

end;

案例:定义存储过程,完成userinfo表的插入功能(完成账户注册这个功能)

--完成userinfo表的插入功能

createorreplaceprocedure pro_userreg(

v_uname in userinfo.uname%type,v_upw in userinfo.upw%type)

as

begin

insertinto userinfo(uname,upw)values(v_uname,v_upw);

end;

执行存储过程

方法一:命令行执行

execute pro_userreg('jack','123456');

方法二:plsql执行

begin

pro_userreg('jack','123456');

end;

方法三:应用程序Java,C#,php调用存储过程

案例二:定义存储过程完成登录

--定义存储过程完成登录

createorreplaceprocedure pro_userlog(

v_uname userinfo.uname%type,v_upw userinfo.upw%type, v_result outnumber)

as

begin

selectcount(*)into v_result from userinfo where

uname = v_uname and upw = v_upw;

end;

declare

v_uname userinfo.uname%type;

v_upw userinfo.upw%type;

v_result number(1);

begin

v_uname :='jack';

v_upw :='123456';

pro_userlog(v_uname,v_upw,v_result);

if v_result =1then

dbms_output.put_line('登陆成功!');

else

dbms_output.put_line('登陆失败!');

endif;

end;

2017-10-31 18:37:14

Oracle 笔记(五)的更多相关文章

  1. Oracle笔记 五、创建表、约束、视图、索引、序列、同义词、表空间

    alter table userInfo add(msn varchar2(20)); 1.建表 create table userInfo ( id number(6), name varchar2 ...

  2. oracle 笔记---(五)__内存管理

    ###查看连接池的信息 select connection_pool,status,maxsize from dba_cpool_info            

  3. Oracle笔记 目录索引

    Oracle笔记 一.oracle的安装.sqlplus的使用 Oracle笔记 二.常用dba命令行 Oracle笔记 三.function .select Oracle笔记 四.增删改.事务 Or ...

  4. 韩顺平Oracle笔记

    韩顺平Oracle笔记 分类: DataBase2011-09-07 10:24 3009人阅读 评论(0) 收藏 举报 oracle数据库sqljdbcsystemstring   目录(?)[-] ...

  5. Oracle笔记 多表查询

    Oracle笔记  多表查询   本次预计讲解的知识点 1. 多表查询的操作.限制.笛卡尔积的问题: 2. 统计函数及分组统计的操作: 3. 子查询的操作,并且结合限定查询.数据排序.多表查询.统计查 ...

  6. C#可扩展编程之MEF学习笔记(五):MEF高级进阶

    好久没有写博客了,今天抽空继续写MEF系列的文章.有园友提出这种系列的文章要做个目录,看起来方便,所以就抽空做了一个,放到每篇文章的最后. 前面四篇讲了MEF的基础知识,学完了前四篇,MEF中比较常用 ...

  7. 《MFC游戏开发》笔记五 定时器和简单动画

    本系列文章由七十一雾央编写,转载请注明出处. http://blog.csdn.net/u011371356/article/details/9332377 作者:七十一雾央 新浪微博:http:// ...

  8. (转)Qt Model/View 学习笔记 (五)——View 类

    Qt Model/View 学习笔记 (五) View 类 概念 在model/view架构中,view从model中获得数据项然后显示给用户.数据显示的方式不必与model提供的表示方式相同,可以与 ...

  9. java之jvm学习笔记五(实践写自己的类装载器)

    java之jvm学习笔记五(实践写自己的类装载器) 课程源码:http://download.csdn.net/detail/yfqnihao/4866501 前面第三和第四节我们一直在强调一句话,类 ...

  10. Oracle笔记(1) 简单查询、限定查询、数据的排序

    Oracle笔记(四) 简单查询.限定查询.数据的排序   一.简单查询 SQL(Structured Query Language) 结构化查询语言,是一种数据库查询和程序设计语言,用于存取数据以及 ...

随机推荐

  1. python文件操作-1.将PDF转成Excel

    # https://www.jianshu.com/p/f33233e4c712 import pdfplumber # 为了操作PDF from openpyxl import Workbook w ...

  2. kotlin面向对象之接口、代理与委托、单例模式

    接口: 对于什么是接口这里就不概述了,跟java中的概念一样,下面直接上代码进行操练: 而男人跟女人的接口当然也是不同的,很显然男人跟女人最大的差别就是拥有"小弟弟"[我黄我暴利] ...

  3. 一、Flux 是什么?

    React 本身只涉及UI层,如果搭建大型应用,必须搭配一个前端框架.也就是说,你至少要学两样东西,才能基本满足需要:React + 前端框架. Facebook官方使用的是 Flux 框架.本文就介 ...

  4. Istio 1.4 部署指南

    原文链接:Istio 1.4 部署指南 Istio 一直处于快速迭代更新的过程中,它的部署方法也在不断更新,之前我在 1.0 版本中介绍的安装方法,对于最新的 1.4 版本已经不适用了.以后主流的部署 ...

  5. UVA - 10829 L-Gap Substrings (后缀自动机+线段树启发式合并)

    题意:统计一段字符串中形如UVU的子串个数(其中V的长度固定为g). 问题等价于求满足$g+1\leqslant |j-i|\leqslant g+LCP(i,j)$的后缀(i,j)的对数,即$\su ...

  6. POJ1185炮兵阵地(DP状态压缩)

    问题描述 司令部的将军们打算在N*M的网格地图上部署他们的炮兵部队.一个N*M的地图由N行M列组成,地图的每一格可能是山地(用"H" 表示),也可能是平原(用"P&quo ...

  7. C# WCF发布服务的元数据的方式

    发布服务元数据的方式有两种:一是基于HTTP-GET协议提供元数据,它是一种绝大多数平台都能支持的简单text-based协议:另一种是元数据交换终结点. 1.基于HTTP-GET协议 <?xm ...

  8. zTree 节点展开

    var treeObj = $("#treeDemo"); $.fn.zTree.init(treeObj, setting, Znode1); zTree_Menu = $.fn ...

  9. JavaScript生成随机数的方法

    一,函数 Math.ceil();  //向上取整. Math.floor();  //向下取整. Math.round();  //四舍五入. Math.random();  //0.0 ~ 1.0 ...

  10. Java内存区域与Java内存模型

    Java内存区域  Java虚拟机在运行程序时会把其自动管理的内存划分为以上几个区域,每个区域都有其用途以及创建销毁的时机,其中蓝色部分代表的是所有线程共享的数据区域,而绿色部分代表的是每个线程的私有 ...