oracle小知识点

一 、 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:

oracle小知识点

现在要递归查询冶炼(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

    

上一篇:Oracle 相关知识点结构图


下一篇:Database Initialization Strategies in Code-First: