一 、 procedure和function:
procedure和function在语法上几乎完全一样,使用上却有小小的差别,
procedure可以单独的调用
在命令行直接exec pro_xxx();
在其他的存储过程中:begin pro_xxx(); end
function一般不在命令行调用,比较麻烦,更常见的是在查询语句
在查询语句中使用:select fun1() from table_name
在其他的存储过程中:begin fun1(); end
由此可见,procedure更适合插入,删除,修改,function更适合查询
二、动态sql语句中的需要执行的sql语句必须是标准的sql语句,不能包含oracle特有的关键字,比如into
例子:从table_name 查询allocatee_id = sales_person的数量
CREATE OR REPLACE FUNCTION "GET_DATA_NUM2" (table_name in varchar2,sales_person in varchar2)
return number
as
n_total number;
v_sql VARCHAR2(500);
begin
v_sql := 'select count(1) from '||table_name||' where allocatee_id ='''||sales_person||'''';
execute immediate v_sql into n_total;
RETURN n_total;
EXCEPTION WHEN OTHERS THEN
return 0;
end;
注意这里的v_sql,不能写成select count(1) into ‘||n_total ||‘from '||table_name||' where allocatee_id ='''||sales_person||'''';
这种语法不符合标准的sql语句,可以编译成功,但是无法得到结果
还有注意最后的sales_person 两端的引号 ,如果变量是数字,拼接动态sql的时候是不用加引号的,但是varchar类型的变量就需要加单引号,而且需要考虑引号的转意
三:oracle的递归查询
递归查询一般用于树形结构的数据,表的两个字段互为父子关系,此时要查询某个节点及节点以下的节点,普通方法就很难实现
有如下表Tree:
现在要递归查询冶炼(id=2)的所有父节点和子节点:
SELECT * FROM tree START WITH id = 2 CONNECT BY PRIOR pid = id -- 递归查询父节点
union
SELECT * FROM tree START WITH id = 2 CONNECT BY pid = PRIOR id; -- 递归查询子节点
转自:http://blog.csdn.net/wang_yunj/article/details/51040029
参考:http://blog.csdn.net/wang_yunj/article/details/51040029