1、PLSQL编程

1.1概念和目的

PL/SQL(Procedure Language/SQL)

PLSQL是Oracle对sql语言的过程化扩展

指在SQL命令语言中增加了过程处理语句(如分支、循环),使SQL语言具有过程处理能力

1.2程序结构

通过PLsqlDeveloper工具的Test Windows创建程序模版或者通过语句在SQLWindows编写

提示:PLSQL语言的大小是不区分的

PL/SQL可以分为三个部分:声明部分、可执行部分、异常处理部分

[declare]  --声明变量,游标(无变量声明可以省略)

begin

--执行部分(方法)处理业务异常

end;

set serveroutput on      --sqlplus  命令窗口

begin

DBMS_output.put_line(“Hello world”);

end;

/   ---需要在程序最后添加一个/标识程序的结束

1.3变量

声明变量的方式

变量名 变量类型(变量长度)   --v_name  varchar2(20)

1.3.1普通变量(char varchar2 date number boolean long)

(1)直接赋值语句:=     --v_name=’zhangsan’

(2)语句赋值,使用select…into…赋值(语法select值into变量)

【示例】打印人员个人信息,包括:姓名、薪水、地址

declare
v_name varchar2(20):=’zhangsan’;
v_sal number;
v_addr varchar2(200);
begin
v_sal:=1580;
select ‘ad’ into v_addr from dual;
DBMS_output.put_line(‘姓名:’|| v_name|| ’薪水:’ || v_sal ||‘地址:’||v_addr);
end;

【示例】查询 emp表中7839号员工的个人信息,打印姓名和薪水

declare
v_name vachar2(20);
v_sal number;
begin
select ename,sal into v_name,v_sal from emp where empno=7839;
DBMS_output.put_line(‘姓名:’|| v_name || ‘,薪水:’|| v_sal);
end;

1.3.2特殊变量类型(引用型变量、记录型变量)

(1)引用型变量

【示例】查询 emp表中7839号员工的个人信息,打印姓名和薪水

declare
v_name emp.ename%TYPE;
v_sal emp.sal%TYPE;
begin
select ename,sal into v_name,v_sal from emp where empno=7839;
DBMS_output.put_line(‘姓名:’|| v_name || ‘,薪水:’|| v_sal);
end;

使用普通变量定义方式,需要知道表中列的类型,而是用引用类型,不需要考虑列的类型,使用%TYPE是非常好的编程风格,因为它使得PL/SQL更加灵活,更加适应于对数据库定义的更新。

(2)记录型变量

接受表中的一行记录,相当于Java中的一个对象

语法:变量名称  表名%ROWTYPE

【示例】查询 emp表中7839号员工的个人信息,打印姓名和薪水…..

declare
v_emp emp%ROWTYPE;
begin
select * into v_emp from emp where empno=7839;
DBMS_output.put_line(‘姓名:’|| v_emp.ename || ‘,薪水:’|| v_emp.sal);
end;

如果有一个表,有100个字段,如果要使用这100字段名,如果使用引用型变量一个个声明,会特别麻烦,记录型变量可以方便的解决这个问题。

错误的使用:

1.记录型变量只能存储一个完整的行数据。

2.返回的行太多了,记录型变量也接受不了。

1.4流程控制

1.4.1条件分支

begin
if 条件1 then 执行1
elsif 条件2 then 执行2
else 执行3
end if;
end;

【示例】判断emp表中记录是否超过20条,10-20之间,或者10条以下

declare
--声明变量接受emp中的数量
v_count number;
begin
select count(1) into v_count from emp;
if v_count>20 then DBMS_output.put_line(‘emp表中的记录数超过了20条为:’|| v_count);
elsif v_count>=10 then DBMS_output.put_line(‘emp表中的记录数在10-20条为:’|| v_count);
else DBMS_output.put_line(‘emp表中的记录数10条以下为:’|| v_count);
end if;
end;

1.4.2循环

在oracle中有三种循环方式,loop循环

语法:

begin
loop
exit when 退出循环条件
end loop;
end;

【示例】打印数字1-10

declare
v_num number:=1;
begin
loop
exit when v_num>10;
dbms_output.put_line(v_num);
v_num+=v_num+1;
end loop;
end;

2、游标

2.1什么是游标

用于临时存储一个查询返回的多行数据(结构集,类似于Java的jdbc连接返回的ResultSet集合),通过遍历游标,可以逐行访问处理该结果集的数据。

游标的使用方式:声明--à打开à读取à关闭

2.2语法

游标声明:

cursor 游标名[(参数列表)] is 查询语句;

游标的打开:

open 游标名;

游标的取值:

fetch 游标名 into 变量列表;

游标的关闭:

close 游标名;

2.3游标的属性

游标的属性

返回值类型

说明

%ROWCOUNT

整型

获得fetch语句返回的数据行数

%FOUND

布尔型

最近的fetch语句返回一行数据则为真,否则为假

%NOTFOUNT

布尔型

与%FOUND属性返回值相反

%ISOPEN

布尔型

游标已经打开时值为真,否则为假

其中%NOTFOUND是在游标中找不到元素的时候返回TRUE,通常用来判断退出循环

2.4创建和使用

无参游标

【示例】使用游标查询emp表中所有员工的姓名和工资,并将其依次打印出来。

declare
--声明游标
cursor c_emp is select ename,sal from emp;
--声明变量用来接受游标中的元素
v_ename emp.ename%type;
v_sal emp.sal%type;
begin
--打开游标
open c_emp;
遍历游标
loop --获取游标中的数据
fetch c_emp into v_ename,v_sal;
--退出循坏条件
exit when c_emp%notfound;
dbms_output.put_line(‘姓名:’||v_name||’,薪水:’||v_sal);
end loop;
--关闭游标
close c_emp;
end;

带参游标

【示例】使用游标查询并打印某部门的员工的姓名和薪资,部门编号为运行时手动输入。

declare
--声明游标
cursor c_emp(v_deptno emp.deptno%type) is
select ename,sal from emp where deptno=v_deptno;
--声明变量用来接受游标中的元素
v_ename emp.ename%type;
v_sal emp.sal%type;
begin
--打开游标
open c_emp;
遍历游标
loop
--获取游标中的数据
fetch c_emp into v_ename,v_sal;
--退出循坏条件
exit when c_emp%notfound;
dbms_output.put_line(v_name || v_sal);
end loop;
--关闭游标
close c_emp;
end;

3、存储过程

3.1概念作用

之前我们编写的PLSQL语句程序可以进行表的操作,判断,循环逻辑处理的工作,但无法重复调用。可以理解之前的代码全部编写在了main方法中,是匿名程序。Java可以通过封装对象和方法来解决复用问题,PLSQL是将一个个PLSQL的业务处理过程存储起来进行复用,这些被存储起来的PLSQL程序称之为存储过程。

存储过程作用:

  1. 在开发过程中,为了一个特定的业务功能,会向数据库进行多次连接关闭(连接和关闭是很耗费资源),需要对数据库进行多次I/O读写,性能比较低。如果把这些业务放到PLSQL中,在应用程序中只需要调用PPLSQL就可以做到连接关闭一次数据库就可以实现我们的业务,可以大大提高效率。
  2. ORACLE官方给的建议:能够让数据库操作的不要放在程序中。在数据库中实现基本上不会出现错误,在程序中操作可能会存在错误。(如果在数据库中操作数据,可以有一定的日志恢复等功能)

3.2语法

create or replace procedure 过程名称[(参数列表)] is
begin end [过程名称];

根据参数的类型,我们将其分为3类讲解:

不带参数的

带输入参数的

带输入输出参数(返回值)的

3.3无参存储

3.3.1创建存储

3.3.2调用存储

create or replace procedure p_hello as
begin
dbms_output.put_line(‘hello word’);
end p_hello; begin
p_hello;
end;

exec p_hello;    -----sqlplus

注:is和as是可以会用的,用哪个都没有关系;过程中没有declare关键字,declare用在语句块中

3.4带输入参数的存储过程

【示例】查询并打印某个员工(如7839号员工)的姓名和薪水—存储过程:要求:调用的时候传入员工编号,自动控制台打印。

create or replace procedure p_querynameandsal(v_empno in emp.empno%type) is
--声明变量接受查询结果
v_name emp.ename%type;
v_sal emp.sal%type;
begin
--查询emp表中某个员工的姓名和薪水并赋值给变量
select ename,sal into v_name,v_sal from emp where empno=v_empno;
dbms_output.put_line(v_name || v_sal);
end;
declare
i integer;
begin
p_querynameandsal(7839);
end exec p_querynameandsal(7839);

3.5带输出参数的存储过程

【示例】输入员工号查询某个员工(7839号员工)信息,要求,将薪水作为返回值输出,给调用的程序使用。

create or replace procedure p_querysal_out(v_empno in emp.empno%type,o_sal out emp.sal%type) as
begin
select sal into o_sal from emp where empno=v_empno;
end;
declare
v_sal emp.sal%type;
begin
p_querysal_out(7839,v_sal);
dbms_output.put_line(v_sal);
end

3.6JAVA程序调用存储过程

需求:如果一条语句无法实现结构集,比如需要多表查询,或者需要复杂逻辑查询,我们可以选择调用存储出你的结果。

结论:通过 Connection对象的prepareCall方法传递一个转义SQL语句可以实现调用存储过程。输入参数直接调用set方法传递,输出参数需要注册后,执行存储过程,通过get方法获取,参数列表的下标是从1开始的。

public interface CallableStatement

用于执行SQL存储过程的界面。 JDBC API提供了存储过程SQL转义语法,允许以标准方式为所有RDBMS调用存储过程。 此转义语法包含一个结果参数和不包含结果参数的表单。 如果使用,结果参数必须注册为OUT参数。 其他参数可用于输入,输出或两者。 参数按顺序依次引用,第一个参数为1。

{?= call <procedure-name>[(<arg1>,<arg2>, ...)]}

{call <procedure-name>[(<arg1>,<arg2>, ...)]}

IN参数值使用从PreparedStatement继承的set方法设置。 所有OUT参数的类型必须在执行存储过程之前进行注册; 它们的值通过这里提供的get方法在执行get 。

import oracle.jdbc.OracleTypes;
import java.sql.CallableStatement;
import java.sql.DriverManager;
import java.sql.Connection;
public class JdbcTest{
public static void main(String[] args){
//1.加载驱动
Class.forName(“oracle.jdbc.driver.PracleDriver”);
//2.获取连接
String url=”jdbc:oracle:thin:@localhost:1521:xe”;
String name=”scott”;
String password=”tigger”;
Connection conn=DriverManager.getConnection(url,name,password);
//3.获取语句对象
String sql=”{call p_querysal_out(?,?)}”;
CallableStatement call=conn.prepareCall(sql);
//4.设置输出参数
call.setInt(1,7839);
//5.注册输出参数
call.registerOutParameter(2,OracleTypes.DOUBLE);
//6.执行存储过程
call.execute();
//7.获取输出参数
double sal=call.getDouble(2);
System.out.println(“薪水:”+sal);
//8.释放资源
call.close();
conn.close();
}
}

视频整理:https://www.bilibili.com/video/av46777605

基于oracle数据库存储过程的创建及调用的更多相关文章

  1. MySQL存储过程的创建及调用

    阅读目录:MySQL存储过程_创建-调用-参数 存储过程:SQL中的“脚本” 1.创建存储过程 2.调用存储过程 3.存储过程体 4.语句块标签 存储过程的参数 1.in:向过程里传参 2.out:过 ...

  2. 《Oracle Database 12c DBA指南》第二章 - 安装Oracle和创建数据库(2.1 安装Oracle数据库软件和创建数据库概览)

    当前关于12c的中文资料比较少,本人将关于DBA的一部分官方文档翻译为中文,很多地方为了帮助中国网友看懂文章,没有按照原文句式翻译,翻译不足之处难免,望多多指正. 2.1 安装Oracle数据库软件和 ...

  3. oracle数据库存储过程中NO_DATA_FOUND不起作用解决

    oracle数据库存储过程中NO_DATA_FOUND不起作用 1.首先创建一个表lengzijiantest,表中只有一个字段f_id ? 1 2 3 4 5 [cpp] CREATE TABLE ...

  4. oracle数据库存储过程中的select语句的位置

    导读:在oracle数据库存储过程中如果用了select语句,要么使用"select into 变量"语句要么使用游标,oracle不支持单独的select语句. 先看下这个存储过 ...

  5. Oracle数据库—— 存储过程与函数的创建

    一.涉及内容 1.掌握存储过程与函数的概念. 2.能够熟练创建和调用存储过程与函数. 二.具体操作 1.创建存储过程,根据职工编号删除scott.emp表中的相关记录. (1)以scott 用户连接数 ...

  6. 编程开发之--Oracle数据库--存储过程和存储函数(2)

    上一小结我们简单介绍了存储过程和存储函数,对存储过程和存储函数有了一个基本的了解,接下来介绍在java程序中如何调用我们创建的存储过程和存储函数 1.在应用程序中调用我们的存储过程 创建一个简单的Ja ...

  7. 编程开发之--Oracle数据库--存储过程在out参数中使用光标(3)

    在本系列学习随笔中的第2节我们留下了2个问题,我们现在讨论在out参数中使用光标. 1.要在out参数中使用光标,我们需要申明一个包的结构,包的结构分为包头和包体,包头只负责申明,包体只负责实现.包头 ...

  8. 2018.6.6 基于Oracle数据库的航天信息系统JDBC练习

    综合练习 一.语言和环境 A.实现语言 Java B.环境要求 JDK 6.0及其以上版本.MyEclipse7.5及其以上版本.Oracle11g.PL/SQL Developer 二.功能要求 开 ...

  9. MYSQL中存储过程的创建,调用及语法

    MySQL 存储过程是从 MySQL 5.0 开始增加的新功能.存储过程的优点有一箩筐.不过最主要的还是执行效率和SQL 代码封装.特别是 SQL 代码封装功能,如果没有存储过程,在外部程序访问数据库 ...

随机推荐

  1. WiFiDog 与 AuthServer

    背景 在一些公共场所(比如公交车.地跌.机场等)连接当地的 WiFi 时会弹出一个验证表单,输入验证信息(比如短信验证码)后就能够通过该 WiFi 联网. 本文将介绍通过 OpenWrt WiFiDo ...

  2. bootstrap 的模态框的宽与高设置

    1,改变bootstrap 的宽与高, 将style=“height:900px”放在<div class = "modal-dialog">或者更外层上,整个模态框的 ...

  3. MUI框架-02-注意事项-适用场景-实现页面间传值

    MUI框架-02-注意事项-适用场景-实现页面间传值 关于开发,我拷贝太多也没什么意义,就请查阅:官方文档:http://dev.dcloud.net.cn/mui/ui/ 快速入门 - 注意事项 有 ...

  4. App更新之dialog数字进度条

    App更新之dialog数字进度条 前言:现在一般的Android软件都是需要不断更新的,当你打开某个app的时候,如果有新的版本,它会提示你有新版本需要更新.当有更新时,会弹出一个提示框,点击下载, ...

  5. 2 pygraphviz在windows10 64位下的安装问题(反斜杠的血案)

    可以负责任的说,这篇文档是windows10安装pygraphviz中,在中文技术网站中最新的文档,没有之一.是自己完全结合各种问题,包括调试等,总结出来的. 问题来源:主要是可视化RvNN网络的树结 ...

  6. iTextSharp 使用详解(转)

    PDF文件是目前比较流行的电子文档格式,在办公自动化(OA)等软件的开发中,经常要用到该格式,但介绍如何制作PDF格式文件的资料非常少,在网上搜来搜去,都转贴的是同一段“暴力”破解的方法,代码片断如下 ...

  7. React学习笔记(六)事件处理

    React学习笔记(六) 五.事件处理 React事件绑定属性的命名采用驼峰写法,不同于传统DOM全部小写. 如果采用JSX的语法,事件函数需要用大括号{}包裹函数名,不同于传统DOM字符串小括号的方 ...

  8. Compare DML To Both REDO And UNDO Size

    SUMMARY you can remember undo rule  the same to redo if you want demo rule that you can look up the ...

  9. MP4

  10. [BZOJ 2763][JLOI 2011] 飞行路线

    2763: [JLOI2011]飞行路线 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 3203  Solved: 1223[Submit][Stat ...