45fan.com - 路饭网

搜索: 您的位置主页 > 网络频道 > 阅读资讯:oracle存储过程的若干问题有哪些?

oracle存储过程的若干问题有哪些?

2016-09-04 07:43:16 来源:www.45fan.com 【

oracle存储过程的若干问题有哪些?

关于oracle存储过程的若干问题备忘

1.在oracle中,数据表别名不能加as,如:

oracle存储过程的若干问题有哪些?selecta.appnamefromappinfoa;-- 正确

oracle存储过程的若干问题有哪些?selecta.appnamefromappinfoasa;-- 错误
也许,是怕和oracle中的存储过程中的关键字as冲突的问题吧
2.在存储过程中,select某一字段时,后面必须紧跟into,如果select整个记录,利用游标的话就另当别论了。

oracle存储过程的若干问题有哪些?selectaf.keynodeintoknfromAPPFOUNDATIONafwhereaf.appid=aidandaf.foundationid=fid;--有into,正确编译

oracle存储过程的若干问题有哪些?selectaf.keynodefromAPPFOUNDATIONafwhereaf.appid=aidandaf.foundationid=fid;--没有into,编译报错,提示:Compilation

oracle存储过程的若干问题有哪些?Error:PLS-00428:anINTOclauseisexpectedinthisSELECTstatement

oracle存储过程的若干问题有哪些?

oracle存储过程的若干问题有哪些?
3.在利用select...into...语法时,必须先确保数据库中有该条记录,否则会报出"no data found"异常。

可以在该语法之前,先利用select count(*) from 查看数据库中是否存在该记录,如果存在,再利用select...into...
4.在存储过程中,别名不能和字段名称相同,否则虽然编译可以通过,但在运行阶段会报错

oracle存储过程的若干问题有哪些?selectkeynodeintoknfromAPPFOUNDATIONwhereappid=aidandfoundationid=fid;--正确运行

oracle存储过程的若干问题有哪些?selectaf.keynodeintoknfromAPPFOUNDATIONafwhereaf.appid=appidandaf.foundationid=foundationid;--运行阶段报错,提示

oracle存储过程的若干问题有哪些?ORA-01422:exactfetchreturnsmorethanrequestednumberofrowsoracle存储过程的若干问题有哪些?
5.在存储过程中,关于出现null的问题

假设有一个表A,定义如下:

oracle存储过程的若干问题有哪些?createtableA(

oracle存储过程的若干问题有哪些?id
varchar2(50)primarykeynotnull,

oracle存储过程的若干问题有哪些?vcount
number(8)notnull,

oracle存储过程的若干问题有哪些?bid
varchar2(50)notnull--外键

oracle存储过程的若干问题有哪些?);
如果在存储过程中,使用如下语句:

oracle存储过程的若干问题有哪些?selectsum(vcount)intofcountfromAwherebid='xxxxxx';
如果A表中不存在bid="xxxxxx"的记录,则fcount=null(即使fcount定义时设置了默认值,如:fcount number(8):=0依然无效,fcount还是会变成null),这样以后使用fcount时就可能有问题,所以在这里最好先判断一下:

oracle存储过程的若干问题有哪些?iffcountisnullthen

oracle存储过程的若干问题有哪些?fcount:
=0;

oracle存储过程的若干问题有哪些?end
if;
这样就一切ok了。
6.Hibernate调用oracle存储过程

oracle存储过程的若干问题有哪些?this.pnumberManager.getHibernateTemplate().execute(

oracle存储过程的若干问题有哪些?oracle存储过程的若干问题有哪些?
newHibernateCallback(){

oracle存储过程的若干问题有哪些?
publicObjectdoInHibernate(Sessionsession)

oracle存储过程的若干问题有哪些?oracle存储过程的若干问题有哪些?
throwsHibernateException,SQLException{

oracle存储过程的若干问题有哪些?CallableStatementcs
=session

oracle存储过程的若干问题有哪些?.connection()

oracle存储过程的若干问题有哪些?.prepareCall(
"{callmodifyapppnumber_remain(?)}");

oracle存储过程的若干问题有哪些?cs.setString(
1,foundationid);

oracle存储过程的若干问题有哪些?cs.execute();

oracle存储过程的若干问题有哪些?
returnnull;

oracle存储过程的若干问题有哪些?}

oracle存储过程的若干问题有哪些?}
);
 

本文地址:http://www.45fan.com/a/question/72000.html
Tags: oracle 存储 关于
编辑:路饭网
关于我们 | 联系我们 | 友情链接 | 网站地图 | Sitemap | App | 返回顶部