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 | 返回顶部