oracle declare语法_基于oracle数据库存储过程的创建及调用

本文详细介绍了Oracle的PL/SQL编程,包括DECLARE语法、变量、流程控制、游标和存储过程的创建及调用。通过实例展示了如何使用DECLARE声明变量,如何处理流程控制,以及如何创建和调用无参、带输入参数和带输出参数的存储过程。还探讨了在Java中如何调用存储过程。
摘要由CSDN通过智能技术生成

教学大纲:

  1. PLSQL编程:Hello World、程序结构、变量、流程控制、游标.
  2. 存储过程:概念、无参存储、有参存储(输入、输出).
  3. JAVA调用存储存储过程.

1. PLSQL编程

1.1. 概念和目的

什么是PL/SQL?

  1. PL/SQL(Procedure Language/SQL)
  2. PLSQL是Oracle对sql语言的过程化扩展 (类似于Basic)
  3. 指在SQL命令语言中增加了过程处理语句(如分支、循环等),使SQL语言具有过程处理能力。

1.2. 程序结构

通过Plsql Developer工具的Test Window 创建 程序模版或者通过语句在SQL Window编写

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

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

-- Created on 2018/3/21 by ADMINISTRATOR 
DECLARE
  -- 声明变量、游标。
  I INTEGER;
BEGIN
  -- 执行语句
​
  --[异常处理]
​
END;

其中 DECLARE部分用来声明变量或游标(结果集类型变量),如果程序中无变量声明可以省略掉

1.3. Hello World

BEGIN
​
  --打印hello world
​
  DBMS_OUTPUT.PUT_LINE('hello world');
​
END;

其中DBMS_OUTPUT 为oracle内置程序包,相当于Java中的System.out,而PUT_LINE()是调用的方法,相当于println()方法

在sqlplus中也可以编写运行PLSQL程序:

SQL> BEGIN
  2
  3    --打印hello world
  4
  5    DBMS_OUTPUT.PUT_LINE('hello world');
  6
  7  END;
  8  /
​
PL/SQL 过程已成功完成。

执行结束后并未显示输出的结果,默认情况下,输出选项是关闭状态的 我们需要开启一下 set serveroutput on

de88625972310e1e4f45fccb330d8fcc.png

SQLPLUS中执行PLSQL程序 需要在程序最后添加一个 / 标识程序的结束

1.4. 变量

PLSQL编程中常见的变量分两大类:

  1. 普通数据类型(char,varchar2, date, number, boolean, long)
  2. 特殊变量类型(引用型变量、记录型变量)

声明变量的方式为

变量名  变量类型(变量长度)  例如: v_name  varchar2(20);

1.4.1. 普通变量

变量赋值的方式有两种:

  1. 直接赋值语句 := 比如: v_name := 'zhangsan'
  2. 语句赋值,使用select …into … 赋值:(语法 select 值 into 变量)

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

-- 打印人员个人信息,包括: 姓名、薪水、地址
DECLARE
  -- 姓名
  V_NAME VARCHAR2(20) := '张三'; -- 声明变量直接赋值
  --薪水
  V_SAL NUMBER;
  --地址
  V_ADDR VARCHAR2(200);
​
BEGIN
​
  --在程序中直接赋值
  V_SAL := 1580;
​
  --语句赋值
  SELECT '上海市传智播客' INTO V_ADDR FROM DUAL;
​
  --打印变量
  DBMS_OUTPUT.PUT_LINE('姓名:' || V_NAME || ',薪水:' || V_SAL || ',地址:' ||V_ADDR);
​
END;

1.4.2. 引用型变量

变量的类型和长度取决于表中字段的类型和长度

通过表名.列名%TYPE指定变量的类型和长度,例如: v_name emp.ename%TYPE;

【示例】查询emp表中7839

  • 2
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值