一、存储过程和函数

  存储过程: 对一个模块的封装
  函数: 功能与存储过程几乎一样

  区别:
    函数必须通过return 关键字返回一个值
  存储过程:
    不需要return返回值

  参数:
    输入型参数
    输出型参数
    输入(输出)型参数

  什么时候用存储过程, 什么时候用函数
    一般来讲, 当只有一个返回值的时候用函数,
    当没有返回值或者需要多个返回值的时候, 用存储过程

二.首先看一下SQL基础

先看要举例的表的内容:

下面开始操作:

首先建一个新的SQL Window:

DECLARE
--声明变量
/*
引用型变量--当前用户下表中的某一列
记录型变量--当前用户下表中的某一行
*/ I NUMBER;
A STUDENT.SNAME%TYPE; --引用型变量,指student表中的sname列
B STUDENT%ROWTYPE; --记录型变量,当前用户下表中的某一行,根据附加条件选出是哪一行 BEGIN
--开始 I := 107;
SELECT S.SNAME INTO A FROM STUDENT S WHERE S.SNO = I;
DBMS_OUTPUT.PUT_LINE('查询结果,a的值为:' || A); --SOL中字符串的拼接用 || SELECT * INTO B FROM STUDENT S WHERE S.SNO = I;
DBMS_OUTPUT.PUT_LINE('查询结果,b的值为:' || B.SNAME); --通过b.~的形式把b中的某一列取出来 END; --结尾

三、游标(cursor)

学会使用游标遍历student表中的学生姓名

--游标(可以看作集合,里面装的是一个个记录型变量),有四个属性,

/*
ISOPEN --游标是否打开
NOTFOUND --bolean值,返回true 或者 false
FOUND --bolean值,返回true 或者 false
ROWCOUNT --已经取出的记录的行数,相当于改变几行就输出几
*/ DECLARE
STU STUDENT%ROWTYPE; CURSOR STUS IS
SELECT * FROM STUDENT; BEGIN OPEN STUS; LOOP
FETCH STUS
INTO STU;
EXIT WHEN STUS%NOTFOUND;
DBMS_OUTPUT.PUT_LINE(STU.SNAME);
END LOOP; CLOSE STUS; END;


四、存储过程(procedure)

输入student表中的班级号,输出学生姓名

第一步:新建SQL Window,编译一段SQL语句,把编译好的语句放到了procedures文件目录下(这是一个查询的存储过程)

CREATE OR REPLACE PROCEDURE HANQI(SCLA IN NUMBER) AS
CURSOR STUS IS
SELECT * FROM STUDENT S WHERE S.CLASS = SCLA;
STU STUDENT%ROWTYPE; BEGIN OPEN STUS; LOOP
FETCH STUS
INTO STU;
EXIT WHEN STUS%NOTFOUND;
DBMS_OUTPUT.PUT_LINE(STU.SNAME);
END LOOP; CLOSE STUS; END;

第二步、重新建立一个Test Window,调用一下存储过程

-- Created on 2017/8/18 by ASUS
declare
-- Local variables here
i integer;
begin
-- Test statements here
hanqi(95031);--在Test窗口中,直接调用就可以了
end; 输出信息为:


第三、看一下命令窗口 Command Window,也可以调用存储过程

Connected to Oracle Database 11g Express Edition Release 11.2.0.2.0
Connected as test@XE SQL> select * from student;
SNO SNAME SSEX SBIRTHDAY CLASS
--- ------ ---- ----------- ----------
108 曾华 男 1977/9/1 95033
105 匡明 男 1975/10/2 95031
107 王丽 女 1976/1/23 95033
101 李军 男 1976/2/20 95033
109 王芳 男 1975/2/10 95031
103 陆君 男 1974/6/3 95031
6 rows selected SQL> set serveroutput on;
SQL> execute hanqi(95031);
匡明
王芳
陆君
PL/SQL procedure successfully completed

五、函数(function)

函数的构造方法和存储过程类似

CREATE OR REPLACE FUNCTION CAL_ADD(A IN NUMBER, B IN NUMBER) RETURN NUMBER AS
C NUMBER;
BEGIN
C := A + B;
RETURN C;
END;

直接调用函数:

六、输出型参数(可以用来当作一个存储过程的返回值,可以是一个,也可以是多个)

新建Sql Window:

CREATE OR REPLACE PROCEDURE HANQI3(SCLA IN NUMBER, VARI OUT NUMBER) AS

BEGIN
UPDATE STUDENT S SET S.SSEX = '女' WHERE S.CLASS = SCLA;
SELECT COUNT(*) INTO VARI FROM STUDENT S WHERE S.CLASS = SCLA;
END;

新建Test Window:

-- Created on 2017/8/18 by ASUS
DECLARE
-- Local variables here
I INTEGER;
BEGIN
-- Test statements here
HANQI3(95031, I);
DBMS_OUTPUT.PUT_LINE('被修改的记录条数:' || I);--有输出型参数的得在Text Window下调用,并打印
END; 执行结果为:

可以通过输出型参数,让存储过程有返回值

Oracle数据库基础--存储过程和函数的更多相关文章

  1. 第一章 oracle数据库基础

    第一章   oracle数据库基础 1.oracle简介-->数据库管理系统    1.1:数据库    1.2:全局数据库名    1.3:数据库实例    1.4:表空间    1.5:数据 ...

  2. Oracle数据库基础入门《二》Oracle内存结构

    Oracle数据库基础入门<二>Oracle内存结构 Oracle 的内存由系统全局区(System Global Area,简称 SGA)和程序全局区(Program Global Ar ...

  3. Oracle数据库基础入门《一》Oracle服务器的构成

    Oracle数据库基础入门<一>Oracle服务器的构成 Oracle 服务器是一个具有高性能和高可靠性面向对象关系型数据库管理系统,也是一 个高效的 SQL 语句执行环境. Oracle ...

  4. 用sql语句导出oracle中的存储过程和函数

    用sql语句导出oracle中的存储过程和函数: SET echo off ; SET heading off ; SET feedback off ; SPOOL 'C:/PRC.SQL' repl ...

  5. Oracle数据库基础知识

    oracle数据库plsql developer   目录(?)[-] 一     SQL基础知识 创建删除数据库 创建删除修改表 添加修改删除列 oracle cascade用法 添加删除约束主键外 ...

  6. 【学习笔记】Y2-1-1 Oracle数据库基础

    Oracle 简介关系型(二维表)数据库 用来存储海量数据在大数据量的并发检索的情况下,性能要高于其他同类数据库产品一般运行环境是Linux和UnixOracle版本中的I(Internet) G(G ...

  7. Oracle 数据库 基础学习 (一) SQL基本知识

    Oracle 从零开始,不知所措.要掌握一种技能,最好的方式是先学会怎么使用它,然后再深入学习,先有样子,再有技术.   一,什么是数据库? 为什么需要数据库? 数据库实质上是一个信息的列表,或者是一 ...

  8. Oracle数据库 基础SQL语句练习

    一.说明 第一次使用Oracle,想做一些练习,熟悉一些oracle. 表:使用的是scott用户,默认的表 具体表讲解,可以参考该文档:https://www.cnblogs.com/xjcheng ...

  9. [转载]Oracle数据库基础--SQL查询经典例题

    Oracle基础练习题,采用Oracle数据库自带的表,适合初学者,其中包括了一些简单的查询,已经具有Oracle自身特点的单行函数的应用 本文使用的实例表结构与表的数据如下: emp员工表结构如下: ...

随机推荐

  1. IIS配置支持apk文件下载

    写在前面 最近项目中涉及到移动端的东西,有一个功能是要下载apk文件,apk为安卓安装程序,但是iis默认是不支持该类型的文件下载的. 解决方案 找到该站点,并切换到功能视图 找到MIME类型,双击进 ...

  2. Android性能优化第(三)篇---MAT比Menmery Monitor更强大

    作者 LooperJing 2016.11.17 16:42* 字数 1687 阅读 1603评论 3喜欢 21 在Android性能优化第(一)篇---基本概念中讲了JAVA的四大引用,讲了一下GC ...

  3. EasyMvc入门教程-基本控件说明(8)提醒导航

    提醒导航顾名思义就是提醒大家注意某些文字了..请看下面的例子: 实现代码如下: @Html.Q().BlockRemind().Text("我可以作为提醒使用") 有的同学会说:这 ...

  4. ylb: SQL表的高级查询-子查询

    ylbtech-SQL Server: SQL Server- SQL表的高级查询-子查询 SQL Server 表的高级查询-子查询. 1,ylb:表的高级查询-子查询返回顶部 --======== ...

  5. implement-stack-using-queues(easy,但也有思考价值)

    https://leetcode.com/problems/implement-stack-using-queues/ 还有种方法,就是利用同一个队列,知道队列长度前提下,把内容从头到尾,再向尾部依次 ...

  6. U盘启动盘恢复为普通盘

    U盘启动盘恢复为普通盘 此操作必须借助软件完成. 所用软件:diskgenius 下载地址: https://pan.baidu.com/s/1geDkK7L 密码: 8888   先将u盘中文件拷贝 ...

  7. javascript回调函数,闭包作用域,call,apply函数解决this的作用域问题

    在JavaScrip中,function是内置的类对象,也就是说它是一种类型的对象,可以和其它String.Array.Number.Object类的对象一样用于内置对象的管理.因为function实 ...

  8. android位置布局

    fill_parent 设置一个构件的布局为fill_parent将强制性地使构件扩展,以填充布局单元内尽可能多的空间.这跟Windows控件的dockstyle属性大体一致.设置一个顶部布局或控件为 ...

  9. initramfs扫描磁盘前改变磁盘上电顺序

    背景: 机械硬盘需要12V 5V电源,此前设计是硬件电路默认5V有效.12V无效,然后系统通过驱动上12V电,对磁盘来说相当于先上5V后上12V,这种方式对大部分磁盘是可以的,但对于日立 HGST磁盘 ...

  10. php减少损耗的方法之一 缓存对象

    即把实例后的对象缓存起来(存入变量),当需要再次实例化时,先去缓存里查看是否存在.存在则返回.否则实例化.