`
钸僢喾耔
  • 浏览: 22932 次
  • 性别: Icon_minigender_1
  • 来自: 西安
最近访客 更多访客>>
文章分类
社区版块
存档分类

Oracle存储过程的若干问题

阅读更多
关于Oracle存储过程的若干问题备忘

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

  select a.appname from appinfo a;-- 正确

  select a.appname from appinfo as a;-- 错误

  也许,是怕和oracle中的存储过程中的关键字as冲突的问题吧

  2.在存储过程中,select某一字段时,后面必须紧跟into,如果select整个记录,利用游标的话就另当别论了。

   select af.keynode into kn from APPFOUNDATION af where af.appid=aid and af.foundationid=fid;-- 有into,正确编译

   select af.keynode from APPFOUNDATION af where af.appid=aid and af.foundationid=fid;-- 没有into,编译报错,提示:Compilation

   Error: PLS-00428: an INTO clause is expected in this SELECT statement

  3.在利用select...into...语法时,必须先确保数据库中有该条记录,否则会报出"no data found"异常。

  可以在该语法之前,先利用select count(*) from 查看数据库中是否存在该记录,如果存在,再利用select...into...

  4.在存储过程中,别名不能和字段名称相同,否则虽然编译可以通过,但在运行阶段会报错

  select keynode into kn from APPFOUNDATION where appid=aid and foundationid=fid;-- 正确运行

  select af.keynode into kn from APPFOUNDATION af where af.appid=appid and af.foundationid=foundationid;-- 运行阶段报错,提示

  ORA-01422:exact fetch returns more than requested number of rows

  5.在存储过程中,关于出现null的问题

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

  create table A(

  id varchar2(50) primary key not null,

  vcount number(8) not null,

  bid varchar2(50) not null -- 外键

  );如果在存储过程中,使用如下语句:

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

  if fcount is null then

   fcount:=0;

  end if;这样就一切ok了。

  6.Hibernate调用oracle存储过程

 this.pnumberManager.getHibernateTemplate().execute(

  new HibernateCallback() ...{

   public Object doInHibernate(Session session)

   throws HibernateException, SQLException ...{

   CallableStatement cs = session.connection().prepareCall("{call modifyapppnumber_remain(?)}");

   cs.setString(1, foundationid);

   cs.execute();

   return null;

  }

 });
分享到:
评论

相关推荐

    Oracle存储过程学习经典[语法+实例+调用].

    Oracle存储过程基础知识 Oracle存储过程的基本语法 Oracle存储过程的若干问题备忘 用Java调用Oracle存储过程总结 在存储过程中做简单动态查询 Oracle存储过程调用Java方法

    oracle存储过程超详细使用手册.

    oracle 存储过程的基本语法,关于oracle存储过程的若干问题备忘,oracle 存储过程语法总结及练习;oracle语法:Oracle触发器语法及实例基础知识(一)。

    自学oracle存储过程

    关于 Oracle 存储过程的若干问题备忘...........................................................................................4 1. 在 Oracle 中,数据表别名不能加 as。......................................

    入门存储过程

    在Oracle中,若干个有联系的过程可以组合在一起构成程序包。 使用存储过程有以下的优点: * 存储过程的能力大大增强了SQL语言的功能和灵活性。存储过程可以用流控制语句编写,有很强的灵活性,可以完成复杂的...

    使用Oracle数据库时的Web分页方法

    常常这些满足条件的记录如此之多,一方面在同一个页面显示显得异常臃肿而不切实际,另一方面用户通常也不会对他们都感兴趣,他们似乎更关心按一定规则排序出现在某些开始位置的若干记录。这就要求我们对满足条件的...

    基于Oracle Spatial的矢量空间数据管理机制.pdf

    * 具有灵活的N层体系结构、Java存储过程及强健的数据安全恢复机制 Oracle Spatial的应用前景广阔,包括GIS系统、空间数据库、地理信息系统等。该系统可以帮助用户更好地管理和分析矢量空间数据,提高工作效率和...

    oracle表空间详解

    因此,Oracle 引入了表空间的概念,以解决存储空间的管理问题。 Oracle 表空间是指一个逻辑概念,由若干个操作系统文件组成的。这些文件可以不是很大,但是它们组成了一个统一的存储空间。一个数据文件只能属于一个...

    Oracle In-Memory白皮书

    Oracle In-Memory 是 Oracle 数据库的 In-Memory 功能,可以将分析查询速度提高若干数量级,帮助企业实时做出业务决策。使用 Database In-Memory,企业可以快速完成分析和报告,从而能够降低成本、提高效率并增强...

    Oracle数据库结构 - ch4.pptx

    Oracle数据库结构是指存储数据的方式,可以分为逻辑存储结构和物理存储结构。 逻辑存储结构(逻辑数据库)用于描述在Oracle内部组织和管理数据的方式。逻辑数据库空间按照由小到大的顺序分别为数据块(Data Block)、...

    Oracle数据库结构ch4.pptx

    数据文件是存储Oracle数据库数据的物理文件,每个数据文件由若干操作系统物理块组成。联机重做日志文件和归档重做日志文件用于记录数据库的所有修改操作,以便在出现故障时恢复数据库。 Oracle数据库结构是一个复杂...

    优化Oracle库表设计的若干方法

    oracle 数据库表的一些设计技巧;数据以何种方式物理存储。如大表的分区,表空间的合理设计等

    oracle_PLSQL_语法详细手册

    表是Oracle中最重要的数据库对象,表存储一些相似的数据集合,这些数据描述成若干列或字段.create table 语句的基本形式用来在数据库中创建容纳数据行的表.create table 语句的简单形式接收表名,列名,列数据类型和大小...

    Oracle-数据库简答题.doc

    答:数据库由若干个表空间组成,表空间由表、索引、视图等逻辑对象组成,表由段 组成,段由区组成,区则由数据块组成。 2.简述Oracle数据库物理结构中包含的文件类型,以及不同类型文件所能起的作用 。 答:物理...

    oracle基础练习.docx

    * 表空间:是 Oracle 存储数据的地方,由若干个数据文件组成,例如 *.dbf。 二、模式和模式对象 * 模式:就是用户,模式对象是数据库对象的集合,例如表、视图、索引、存储过程。 三、卸载和安装注意事项 * 卸载...

    SybaseToad:小巧的oracle数据库查询修改工具

    新增功能:支持informix、增加export table界面、增加存储过程执行界面、增加存储过程重编译、增加表对象的触发器修改查看。修改bug若干。 功能类似toad或plsql: 1,支持语法高亮,显示表提示,类似plsql。 2,能...

    Oracle Database 18c In-Memory技术概述.docx

    Oracle Database 18c 中的 Oracle Database In-Memory 技术概述是 Oracle 数据库增添了 In-Memory 功能,能以透明的方式将分析查询速度提高若干数量级,从而有助于实时做出业务决策。使用 Database In-Memory,企业...

    Oracle10g精简绿色版

    ● 自动存储管理(ASM) :这是一项Oracle欲代替存储陈列软件、卷管理软件的技术,它允许用户创建镜像、条带化硬件。在Oracle 10g网格计算环境中,它允许用户比较方便地在节点分配硬盘与硬盘组,从而获得负载均衡的...

    ORACLE数据库分区技术及其应用.pdf

    Oracle数据库分区技术是指将大表或索引按照某种策略划分成多个相对较小的、各自独立的存储空间,每个存储空间作为分区可以被独立地管理和操作。分区技术可以提高大表和索引在物理一级的可管理性,从而支撑无限膨胀...

    Oracle VM Manager简介

    从图 9 可以看出,云端由若干服务器池和一个外部存储组成,每个服务器池包含若干台服务器(称为计算节点)。服务器池可以是集群,也可以不是集群。 服务器池中的计算节点上安装 Oracle VM Server 虚拟软件(基于 Xen...

Global site tag (gtag.js) - Google Analytics