oracle 函数function语法及简单实例

1546年前oracle数据库4987

函数调用限制
1、SQL语句中只能调用存储函数(服务器端),而不能调用客户端的函数
2、SQL只能调用带有输入参数,不能带有输出,输入输出函数
3、SQL不能使用PL/SQL的特有数据类型(boolean,table,record等)
4、SQL语句中调用的函数不能包含INSERT,UPDATE和DELETE语句

1.function函数的语法:

  create or replace function function_name (  
     argu1 [mode1] datatype1, --定义参数变量mode: in or out 
     argu2 [mode2] datatype2 --定义参数变量  
 ) return datatype --定义返回的数据类型  
is    
begin  
end;

执行:

var v1 varchar2(100)   
exec :v1:=function_name 
或
select  function_name   from dual;

2.不带任何参数的定义

create or replace function get_user   
return varchar2   
is   
Result varchar2(50); --定义变量  
begin   
select username into Result from user_users;   
return(Result); --返回值  
end get_user;

3.带有in参数的

create or replace function GET_POIALL(  
empname in varchar2  
) return number   
is   
Result number;   
begin   
select sal into Result from emp where ename=empname;   
return(Result);   
end;

执行:

SQL> var sal number   
SQL> exec :sal:=get_sal('scott');  
或者
 select  GET_POIALL('0')  from dual;

4.带out参数的

create or replace function get_info(  
e_name varchar2,  
job out varchar2  
) return number   
Is  
Result number;   
begin   
select sal,job into Result,job from emp where ename=e_name;   
return(Result);   
end;

执行:

SQL> var job varchar2(20)   
SQL> var dname varchar2(20)   
SQL> exec :dname:=get_info('SCOTT',:job)


相关文章

linux系统  vi命令修改文件内容

linux系统 vi命令修改文件内容

以修改木项目application.yml里的内容为例:进入vi,输入以下命令,格式为:vi 文件路径vi /data/AAS-V9.0/domains/mydomain/deploy/sd...

樊山越玲 一周年

樊山越玲 一周年

2015-12-25樊先森:周末有约吗?玲玲:有约,不过也得先以你为主啊。樊先森:昂,这样说我还挺开心的。2015-3-26玲玲:亲爱的,苹果是你买的吗?已经收到了,谢谢老公玲玲:有点小惊喜樊先森:那...

Jfinal+Jquery uploadify实现多文件上传实例

Jfinal+Jquery uploadify实现多文件上传实例

包文件外部jar包jfinal-2.0-bin-with-src.jar(JFinal核心包)  fastjson-1.2.7.jar(用于json数据的处理)  cos-26De...

每次开机checking file system on d

 解决方案:点击左下角(开始)- (运行)输入(CMD)回车 - 进入CMD界面- 输入(d:)回车 - 输入(chkdsk /f)中间有空格。回车,出现提示按Y键,完成后,重启一次会检...

tuya SaaS前端框架本地运行时候报错Delete `␍`eslint(prettier/prettier)

 根据官方文档的步骤,本地idea运行tuya的 SaaS前端框架,在执行编译命令yarn run build 时报错Delete `␍`eslint(prettier/prett...

ssh重启linux下的 mysql

1、查看mysql版本方法一:status;方法二:select version();2、Mysql启动、停止、重启常用命令a、启动方式1、使用 service 启动:[root@localhost...

评论列表

广东硅谷学院
2018-06-22 09:42:10

挺实用的,收藏了
学好IT好工作就选硅谷学院,学技能拿文凭事半功倍,紧跟专业教师一起冲浪IT行业。我们有建设学习型专业师资团队,教师领跑学生紧随其后。广东硅谷学院热招2018年高考毕业生,招生热线88989555,QQ:800015777网站:http://www.sve.com.cn

发表评论    

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。