首页 > 新闻中心
专业知识

高速焊接工艺

浏览:725次    发布日期: 2017-06-03


概述

说实话,我不知道如何在正常工作中创建存储过程,创建函数,创建包和其他语法。但是我相信,每个接受采访的人基本上都会对此进行笔试,因此我将测试存储过程和功能。总结一下包的语法并做一个备忘录!每个人都可以理解语法,最好记住...

一、 Oracle创建存储过程(过程)

存储过程是一组完成特定功能的SQL语句,这大大提高了SQL语句的功能和灵活性。存储过程被编译并存储在数据库中,因此执行存储过程比执行封装在存储过程中的SQL语句效率更高。

1、基本语法

create or replace procedure update_emp_sal
(Name in out type,
 Name in out type, ...
) is
begin
 
end update_emp_sal;

2、示例:

2. 1、修改emp表的ename字段

create or replace procedure update_emp
(
v_empno varchar2,
v_ename varchar2
) is
begin
update emp set ename=v_ename where empno=v_empno; 
end update_emp;

超全的oracle存储过程、函数及包的语法及使用说明

调用方法如下:

SQL>exec update_emp('7934','test');

超全的oracle存储过程、函数及包的语法及使用说明

2. 2、具有返回值的存储过程:只需返回empno = 7934的sal值

create or replace procedure emp_out_sal(v_empno in varchar2,
 v_sal out number) is
 vsal number(7, 2);
begin
 select sal into vsal from emp where empno = v_empno;
 v_sal := vsal;
end;

超全的oracle存储过程、函数及包的语法及使用说明

调用具有返回值的过程

SQL> var vsal number
SQL> exec emp_out_sal('7934',:vsal);

超全的oracle存储过程、函数及包的语法及使用说明

二、 Oracle创建函数(函数)

1、基本语法:

create or replace function (Name in type, Name in type, ...) return number is
 Result number;
begin
 return (Result);
end ;

2、示例

2. 1、查询ename = SCOTT的工资

create or replace function ret_emp_sal(v_ename varchar2) return number is
 v_sal number(7, 2);
begin
 select nvl(sal, 0)
 into v_sal
 from emp
 where lower(ename) = lower(v_ename);
 return v_sal;
end;

超全的oracle存储过程、函数及包的语法及使用说明

调用此函数:

SQL> var vsal number
SQL> call ret_emp_sal('SCOTT') into :vsal;
 
Method called
vsal
---------
3000

超全的oracle存储过程、函数及包的语法及使用说明

sql语法范例手册 pdf_oracle sql语法_oracle sql语法手册

三、 Oracle创建程序包(程序包)

包用于与组合逻辑有关的过程和功能。它由两部分组成:包装规格和包装主体。包规范用于定义常见的常量oracle sql语法手册华体会登录 ,变量,过程和函数。您可以使用CREATE PACKAGE命令创建程序包规范oracle sql语法手册乐鱼官网爱游戏app官方下载 ,并使用CREATE PACKAGE BODY创建程序包主体。

1、创建包装说明:

create package emp_pkg is
 procedure emp_update_ename(v_empno varchar2, v_ename varchar2);
 function emp_get_sal(v_empno varchar2) return number;
end;

2、创建程序包主体

create or replace package body emp_pkg
is
 procedure emp_update_ename
 (
 v_empno varchar2,
 v_ename varchar2
 )
 is
 vename varchar2(32);
 begin 
 update emp set ename=v_ename where empno=v_empno;
 commit;
 select ename into vename from emp where empno=v_empno;
 dbms_output.put_line('雇员名称:'||vename); 
 end;
 
 function emp_get_sal
 (
 v_empno varchar2
 )
 return number is
 vsal number(7,2);
 begin
 select sal into vsal from emp where empno=v_empno;
 return vsal;
 end;
end;

sql语法范例手册 pdf_oracle sql语法_oracle sql语法手册

在此提醒您,如果在不创建程序包规范的情况下创建程序包主体华体会 ,则它将失败。要使用程序包鸭脖app官网 ,必须先创建程序包规范,然后再创建程序包主体。

在调用包过程和函数时,请在过程和函数名称之前将包名称添加为前缀(包名称。子例程名称)。如果要访问其他程序的程序包,则需要在程序包名称之前添加程序名称(程序名称。程序包名称。子例程名称)

3、通话包裹

SQL> var vsla number
SQL> call emp_pkg.emp_get_sal('7934') into :vsla;
SQL> set serveroutput on;
SQL> exec emp_pkg.emp_update_ename('7934','huangweibo');
SQL> call emp_pkg.emp_update_ename('7934','huangweibo');
SQL> select * from dual;

超全的oracle存储过程、函数及包的语法及使用说明

超全的oracle存储过程、函数及包的语法及使用说明

存储过程和功能基本相同。只是函数被限制为仅返回一个标量,而存储过程可以返回多个。函数可以嵌入SQL中,也可以在SQL语句(例如SELECT)中调用,但是存储过程不能。执行的本质是相同的,可以理解,函数是一种存储过程。一个包中有多个存储和功能。当为某个项目设计了某种类型的存储或功能时,可以将它们放在一个包装中以便于管理。

稍后将共享更多DBA内容,有兴趣的朋友可以关注它!

超全的oracle存储过程、函数及包的语法及使用说明

万狗体育
分享到:
上一篇:焊割自动化解决方案
下一篇:
返回列表
首页 |  关于我们 |  新闻中心 |  产品中心 |  成功案例 |  联系我们 | 
分享到: