ORACLE函数详解【weber出品】
一、什么是函数
一个函数:
1. 是命名的PL/SQL块,必须返回一个值
2. 可以存储到数据库中重复执行
3. 可以作为表达式的一部分或者提供一个参数值
二、创建函数的语法
必须至少有一个返回值,创建模板:
CREATE [OR REPLACE] FUNCTION function_name [(parameter1 [mode1] datatype1, ...)]
RETURN datatype IS|AS
[local_variable_declarations; …]
BEGIN -- actions;
RETURN expression;
END [function_name];
创建函数示例:
create or replace function get_sal(v_employee_id employees.employee_id%type)
return number is
v_salary employees.salary%type;
begin
select salary
into v_salary
from employees
where employee_id = v_employee_id;
return v_salary;
end;
三、执行函数的方式:
1. 作为表达式的一部分调用
1.1 使用主机变量获取结果
SQL> conn hr/hr SQL> variable sal number(); SQL> execute :sal:=get_sal(); PL/SQL 过程已成功完成。 SQL> col sal for SQL> print sal; SAL
-------
1.2 使用本地变量获取结果
declare
sal number();
begin
sal := get_sal();
dbms_output.put_line('员工的工资:' || sal);
end;
2. 作为参数传递给另一个子程序
SQL> set serveroutput on
SQL> execute dbms_output.put_line(get_sal()); PL/SQL procedure successfully completed SQL> select get_sal() from dual;
GET_SAL()
------------
3. 在SQL语句中使用
SQL> select get_sal() from dual;
GET_SAL()
------------
四、用户定义的函数在SQL语句中的优势
函数:
1. oracle自定义的函数
2. 用户自定义的函数
优势:
1. 在SQL无法使用的时候,可以扩展SQL语句
2. 在WHERE子句中用来过滤数据时,可以提高过滤数据的效率
3. 可以操作数据
在SQL表达式中使用函数: 示例
create or replace function tax(value employees.salary%type) return number is
begin
return(value * 0.08);
end;
SQL> select first_name,tax(salary) from employees;
FIRST_NAME TAX(SALARY)
-------------------- -----------
Donald
Douglas
Jennifer
.......
Kevin
rows selected
五、用户定义函数的调用位置
用户定义的函数与内置的单行函数一样,可以用于:
1. SELECT列表
2. WHERE和HAVING子句的条件表达式
3. 查询语句的CONNECT BY, START WITH, ORDER BY, GROUP BY ,INSERT语句的VALUE子句、UPDATE语句的SET子句
六、在SQL表达式中调用函数的限制
在SQL表达式中调用函数的限制:
1. 在SQL语句中只能调用存储函数(服务器端),而不能调用客户端的函数
2. 在SQL语句中调用的函数只能带有输入参数(IN),而不能带有输出参数(OUT)和输入输出参数(INOUT)
3. 在SQL语句中调用的函数只能使用SQL所支持的标准数据类型,而不能使用PL/SQL的特有数据类型(例如BOOLEAN,TABLE和RECORD等)
4. 在SQL语句中调用的函数不能包含INSERT,UPDATE,和DELETE语句
我们来验证第四条:
create or replace function dml_call_sal(sal number) return number is
begin
insert into employees(employee_id, last_name, email, hire_date, job_id, salary)
VALUES
(, 'Frost', 'jfrost@company.com', SYSDATE, 'SA_MAN', sal);
return (sal+);
end;
在sql中调用这个函数:
SQL> update employees set salary=dml_call_sal() where employee_id=;
update employees set salary=dml_call_sal() where employee_id=
ORA-: 表 HR.EMPLOYEES 发生了变化, 触发器/函数不能读它
ORA-: 在 "HR.DML_CALL_SAL", line
七、查看函数的数据字典
以下视图可以查看函数的信息:
USER_SOURCE ALL_SOURCE DBA_SOURCE SELECT text
FROM user_source
WHERE type = 'FUNCTION'
and name ='DML_CALL_SAL'
ORDER BY line;
使用USER_OBJECTS查看类型为FUNCTION的对象名
SELECT object_name
FROM user_objects
WHERE object_type = 'FUNCTION';
SQL> select object_name from user_objects where object_type='FUNCTION';
OBJECT_NAME
--------------------------------------------------------------------------------
GET_SAL
TAX
DML_CALL_SAL
使用USER_SOURCE查看函数的内容
SQL> select text,line,name ,type from user_source where type='FUNCTION' and name='DML_CALL_SAL';
TEXT LINE NAME TYPE
-------------------------------------------------------------------------------- ---------- ------------------------------ ------------
function dml_call_sal(sal number) return number is DML_CALL_SAL FUNCTION
begin DML_CALL_SAL FUNCTION
insert into employees(employee_id, last_name, email, hire_date, job_id, salary DML_CALL_SAL FUNCTION
VALUES DML_CALL_SAL FUNCTION
(, 'Frost', 'jfrost@company.com', SYSDATE, 'SA_MAN', sal); DML_CALL_SAL FUNCTION
return (sal+); DML_CALL_SAL FUNCTION
end; DML_CALL_SAL FUNCTION
rows selected
八、过程与函数对比
九、删除函数
删除函数:
语法: DROP FUNCTION function_name 示例:DROP FUNCTION get_sal;
当函数被删除以后,在函数的所有权限都被删除
The CREATE OR REPLACE 语法等于先删除函数,燃烧再创建,权限仍然被保留
十、权限
1. 定义者权限(default)
SQL> conn hr/hr
Connected.
SQL> create table e as select * from employees; Table created. SQL> select count(*) from e; COUNT(*)
---------- SQL> conn scott/tiger;
Connected.
SQL> create table e as select * from emp;
Table created.
SQL> select count(*) from e;
COUNT(*)
----------
14
SQL> conn hr/hr;
Connected.
SQL> create or replace procedure insert_e is
2 begin
3 insert into e select * from e;
4 commit;
5 end;
6 /
Procedure created.
SQL> show user
USER is "HR"
SQL> grant execute on insert_e to scott;
Grant succeeded.
SQL> conn scott/tiger
Connected.
SQL> select count(*) from e;
COUNT(*)
----------
14
SQL> conn hr/hr;
Connected.
SQL> select count(*) from e;
COUNT(*)
----------
107
SQL> conn scott/tiger;
Connected.
SQL> execute hr.insert_e;
PL/SQL procedure successfully completed.
SQL> conn hr/hr
Connected.
SQL> select count(*) from e;
COUNT(*)
----------
214
2. 调用者权限
默认情况,程序以其拥有者身份(定义者)执行。定义者权限的程序与其所在模式绑定,调用对象不需要加上模式完整名称。例如,假如模式HR和OE都有deparments表,HR拥有的程序可直接调用departments而不用HR.departments.而如果OE调用HR的程序,程序仍然调用的是HR的departments.
如果希望不同模式(schema)调用相同的程序却可以操作各自拥有的对象,就可以在定义程序的时候加上AUTHID CURRENT_USER。
conn hr/hr create or replace procedure insert_e authid current_user is
begin
insert into e select * from e;
commit;
end; grant execute on insert_e to scott; conn scott/tiger execute insert_e; select count(*) from e; COUNT(*)
---------- conn hr/hr select count(*) from e; COUNT(*)
----------
ORACLE函数详解【weber出品】的更多相关文章
- oracle函数详解-转
1.SQL 语句基础 下面给出SQL语句的基本介绍. 1.1.SQL语句所用符号 操作符 用途 例子 + - 表示正数或负数,正数可省去 + -1234.56 + 将两个数或表达式进行相加 A=c+b ...
- Netsuite Formula > Oracle函数列表速查(PL/SQL单行函数和组函数详解).txt
PL/SQL单行函数和组函数详解 函数是一种有零个或多个参数并且有一个返回值的程序.在SQL中Oracle内建了一系列函数,这些函数都可被称为SQL或PL/SQL语句,函数主要分为两大类: 单行函数 ...
- Oracle中的substr()函数 详解及应用
注:本文来源于<Oracle中的substr()函数 详解及应用> 1)substr函数格式 (俗称:字符截取函数) 格式1: substr(string string, int a, ...
- oracle 数据类型详解---日期型(转载)
oracle 数据类型详解---日期型 oracle数据类型看起来非常简单,但用起来会发现有许多知识点,本文是我对ORACLE日期数据类型的一些整理,都是开发入门资料,与大家分享: 注:由于INTER ...
- oracle rowid 详解
oracle rowid详解 今天是2013-09-15,存储在数据库中的每一行数据都有一个地址,oracle使用rowid数据类型在存储地址.rowid有如下类别: 1)physical rowid ...
- Oracle索引详解
Oracle索引详解(二) --索引分类 Oracle 提供了大量索引选项.知道在给定条件下使用哪个选项对于一个程序的性能来说非常重要.一个错误的选择可能会引发死锁,并导致数据库性能急剧下降或进程 ...
- Oracle date 详解
oracle 数据类型详解---日期型 oracle数据类型看起来非常简单,但用起来会发现有许多知识点,本文是我对ORACLE日期数据类型的一些整理,都是开发入门资料,与大家分享:注:由于INTERV ...
- 【Oracle】详解ORACLE中的trigger(触发器)
本篇主要内容如下: 8.1 触发器类型 8.1.1 DML触发器 8.1.2 替代触发器 8.1.3 系统触发器 8.2 创建触发器 8.2.1 触发器触发次序 8.2.2 创建DML触发器 8.2. ...
- 问题:Oracle出发器;结果:1、Oracle触发器详解,2、Oracle触发器示例
ORACLE触发器详解 本篇主要内容如下: 8.1 触发器类型 8.1.1 DML触发器 8.1.2 替代触发器 8.1.3 系统触发器 8.2 创建触发器 8.2.1 触发器触发次序 8.2.2 创 ...
随机推荐
- js带箭头左右翻动控制
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- QT小技巧学习记录
1. 光标定位最后一行 ui->revTextBrower->moveCursor(QTextCursor::End); 2. 隐藏标题栏3. 如果不考虑跨平台的话,在隐藏标题栏的 ...
- web标准(复习)--4 纵向导航菜单及二级弹出菜单
今天我们开始学习纵向导航菜单及二级弹出菜单,包含以下内容和知识点: 纵向列表 标签的默认样式 css派生选择器 css选择器的分组 纵向二级列表 相对定位和绝对定位 一.纵向列表纵向列表或称为纵向导航 ...
- lazy loading img 图片延迟加载
http://yunpan.cn/cVsjPW6dgbcsh (提取码:b5db)
- HTML&CSS基础学习笔记1.2-HTML的全局属性?
HTML元素都有属性,下面的这些全局属性是所有的HTML元素都可以使用的. 常见的有: HTML元素也有一些本身自己独特的属性,我们以后的笔记中有机会,会再为大家介绍哦. 下面是代码测验,具体的内容可 ...
- mac下 配置tomcat
第一步: 1.打开你的终端:然后输入 pico .bash_profile 回车 第二步: 2. 然后添加你tomcat放入的路径的path 编辑完后,control+x (保存) 继 ...
- Swift—属性观察者-备
为了监听属性的变化,Swift提供了属性观察者.属性观察者能够监听存储属性的变化,即便变化前后的值相同,它们也能监听到. 属性观察者主要有以下两个: willSet:观察者在修改之前调用. didSe ...
- GET方式的中文编码与解码
- Cracking the coding interview--Q1.1
原文: Implement an algorithm to determine if a string has all unique characters. What if you can not u ...
- C# 代码转换到Python
下载地址:http://pan.baidu.com/s/1dDAZJxv SharpDevelop 3.1 now supports converting C# and VB.NET code to ...