在OAF VO开发中,Binding Style主要用于对VO的where clause做动态传值,总共有三种方式

1.       Oracle Named

2.       Oracle Positional

3.       JDBC Positional

Oracle Positional

Oracle Positional 是最常用的一种方式,Oracle文档的介绍是

This style represents parameters as colons followed by numbers, as in the following code fragment:WHERE bar = :1 AND foo = :2 In this style, the numbers are just for easier readability: Parameters are passed into the view object in the order in which the numbers occur. The above fragment, for example, is equivalent to WHERE bar = :70 AND foo = :3

简单来说,这种方式中的参数都是以‘:’和数字来声明的,比如:WHERE bar = :1 AND foo = :2。这种方式来说,数字只是用来增加可读性,参数只会根据数字在VO Sql Statement中出现的顺序传入到View Object中,而不会根据数字的大小而传入。比如,上面的代码片段和下面这个是一样的效果WHERE bar = :70 AND foo = :3,下面会在实现中具体介绍。

如何在VO使用Oracle Positional绑定方式

首先,我们需要在VO定义界面上进行设置,

1.       Binding Style 设成 Oracle Positional

2.       在VO SQL Statement 中的where clause里面使用 ‘:’加上数字作为参数,比如 :1.

在VO上设置完之后,我们需要执行VO查询之前,使用vo.setWhereClauseParam(int index, Object value)对VO的绑定参数进行赋值,如下面的代码。

public void initShipToLocation(String org_id)

{

RcvShipToLocationVOImpl vo =this.getRcvShipToLocationVO1();

vo.setWhereClause(null);

vo.setWhereClauseParam(0, new Number(Integer.parseInt(org_id)));

}

 

 

使用Oracle Positional 绑定方式需要注意的问题

1.         在使用vo.setWhereClauseParam(int index, Object value)进行赋值的时候, index一定是从0开始的,接着就是1,2,3,…… .但是在VO SQL Statement中,参数却不是必须从0开始,而且后面的参数的数值也不必比前面的大。比如下面的也是可以的,

但是在使用vo.setWhereClauseParam()给VO绑定参数值的时候一定要使用0和1作为index,而且index必须和绑定参数在VO SQL Statement中出现的顺序对应的类型一致,比如

public void initShipToLocation(String org_id)

{

RcvShipToLocationVOImpl vo =this.getRcvShipToLocationVO1();

vo.setWhereClause(null);

vo.setWhereClauseParam(0, new Number(Integer.parseInt(org_id)));

vo.setWhereClauseParam(1, "hello");

}

如果使用了其它的任何的Index,就会抛出下面的异常(无效的列索引)

oracle.apps.fnd.framework.OAException: oracle.jbo.SQLStmtException: JBO-27122:Invalid column index …..

2.         如果在VO SQL Statement中使用了:加数字作为绑定参数,并且在给VO设置绑定值的时候使用了vo.setWhereClauseParam(),那么一定要保证VO的绑定方式(Binding Style)为 Oracle Positional,否则可能会出现下面的异常(无效的列类型)

oracle.apps.fnd.framework.OAException: oracle.jbo.SQLStmtException: JBO-27122:Invalid column type …..

3.         如果VO SQL Statement中两个或多个绑定参数每次一定是一样的值传入,在VO SQL Statement虽然可以使用相同的数字作为绑定参数,但在使用vo.setWhereClauseParam()设置绑定值的时候也要分别设值,而且建议不要使用相同的数字作为绑定参数。

public void initShipToLocation(String org_id)

{

RcvShipToLocationVOImpl vo =this.getRcvShipToLocationVO1();

vo.setWhereClause(null);

vo.setWhereClauseParam(1, "hello");

vo.setWhereClauseParam(2, "hello");

vo.setWhereClauseParam(0, new Number(Integer.parseInt(org_id)));

}

否则VO在执行查询的时候会报下面的错误

java.sql.SQLException: 索引中丢失  IN 或 OUT参数:: 8

Oracle Named

Oracle Named 绑定方式是VO定义中的默认方式,也是非常常用的一种方式,Oracle文档的介绍是

This style represents parameters as colons followed by identifiers, as in the following code fragment:WHERE bar = :barparam AND foo = :fooparam Unlike the positional styles, the names of the parameters are actually used when the application fills the parameter values.

顾名思义,Oracle Named方式就是‘:’和名字的方式来表示参数,而不是像Oracle Positional用数字.这种方式的好处就是相同的参数可以使用同一个名字,在VO初始化参数的时候对相同名字的参数只用初始化一次就可以了,在下面的实现中会具体介绍.

如何在VO使用Oracle Named绑定方式

首先,我们需要在VO定义界面上进行设置,

1.       在Bind Variable 页面上定义要在VO SQL Statement中使用的绑定参数的名字,类型和默认值。

2.       在VO SQL Statement页面上设置Binding Style为 Oracle Named.

3.       在VO SQL Statement 中的where clause里面使用 ‘:’加上Bind Variable中定义的Bind variable作为参数,比如 :inv_org_id,而且这些参数我们可以使用多次。

在VO定义上设置完之后,我们需要执行VO查询之前,使用vo.setNamedWhereClauseParam(String name, Object value)对VO的绑定参数进行赋值,如下面的代码。

public void initRcvSubinventory(String orgId, String itemId, String receiptSourceCode)

{

RcvSubinventoryLovImpl vo =this.getRcvSubinventoryLov1();

vo.setWhereClause(null);

vo.setWhereClauseParams(null);

vo.setNamedWhereClauseParam("inv_org_id", orgId);

vo.setNamedWhereClauseParam("rcv_item_id", itemId);

vo.setNamedWhereClauseParam("receipt_source_code", receiptSourceCode);

}

使用Oracle Named 绑定方式需要注意的问题

1.       在使用Oracle Named绑定方式的时候一定要声明Bind Variable,如果没有声明就在VO SQL Statement中使用,在运行时就会出现下面的错误.

(oracle.jbo.SQLStmtException) JBO-27122: SQL error during statement preparation.

## Detail 0 ##

(java.sql.SQLException) Missing IN or OUT parameter at index:: 1

2.       相反,如果定义了Bind Variable, 但是在VO SQL Statement中没有使用他,或者定义的类型错误,在运行时就会抛出下面的错误

oracle.jbo.SQLStmtException: JBO-27122: SQL error during statement preparation.

## Detail 0 ##

java.sql.SQLException: Attempt to set a parameter name that does not occur in the

SQL: inv_org_id

3.       如果在定义Bind Variable的时候没有指定默认值,而且在运行时没有使用vo.setNamedWhereClauseParam()初始化Bind Variable,那么Bind Variable默认将会使用NULL值.但一般情况下,NULL不是用户需要的,请记得设置默认值或者运行时为Bind Variable指定值。

JDBC Positional

这种绑定方式在EBS OAF开发中是不常见的,因为Oracle文档中是这么介绍的

This style represents parameters as question marks, as in the following code fragment:WHERE foo = ? AND bar = ?. This should be used only if you are working with non-oracle database.

因为EBS应该没有使用非ORACLE数据库的,所以应该在OAF开发中是用不到的,但是在ADF开发中应该是用得到的,但这个不在我们今天讨论的范围之内。

参考:Tavor - http://blog.csdn.net/tavor/article/details/17199223

OAF_VO系列3 - Binding Style绑定方式的更多相关文章

  1. 控制文本和外观------Style Binding(Style属性绑定)

    目的 style绑定是添加或删除一个或多个DOM元素上的style值.比如当数字变成负数时高亮显示,或者根据数字显示对应宽度的Bar.(注:如果你不是应用style值而是应用CSS class的话,请 ...

  2. WCF编程系列(三)地址与绑定

    WCF编程系列(三)地址与绑定   地址     地址指定了接收消息的位置,WCF中地址以统一资源标识符(URI)的形式指定.URI由通讯协议和位置路径两部分组成,如示例一中的: http://loc ...

  3. SNF快速开发平台MVC-各种级联绑定方式,演示样例程序(包含表单和表格控件)

    做了这么多项目,经常会使用到级联.联动的情况. 如:省.市.县.区.一级分类.二级分类.三级分类.仓库.货位. 方式:有表单需要做级联的,还是表格行上需要做级联操作的. 实现:实现方法也有很多种方式. ...

  4. wpf中UserControl的几种绑定方式

    我们经常会抽取一些可重用的控件,某个属性是否需要重用,直接决定了这个属性的绑定方式. 1.完全不可重用的控件 有一些与业务强相关的控件,它们的属性完全来自ViewModel,越是相对复杂的控件,越容易 ...

  5. Vue中class与style绑定

    gitHub地址:https://github.com/lily1010/vue_learn/tree/master/lesson07 一 用对象的方法绑定class 很简单,举个栗子: <!D ...

  6. Knockout.Js官网学习(style绑定、attr绑定)

    Style绑定 style绑定是添加或删除一个或多个DOM元素上的style值.比如当数字变成负数时高亮显示,或者根据数字显示对应宽度的Bar.(注:如果你不是应用style值而是应用CSS clas ...

  7. 你想要的都在这里,ASP.NET Core MVC四种枚举绑定方式

    前言 本节我们来讲讲在ASP.NET Core MVC又为我们提供了哪些方便,之前我们探讨过在ASP.NET MVC中下拉框绑定方式,这节我们来再来重点看看枚举绑定的方式,充分实现你所能想到的场景,满 ...

  8. 前端MVC Vue2学习总结(三)——模板语法、过滤器、计算属性、观察者、Class 与 Style 绑定

    Vue.js 使用了基于 HTML 的模版语法,允许开发者声明式地将 DOM 绑定至底层 Vue 实例的数据.所有 Vue.js 的模板都是合法的 HTML ,所以能被遵循规范的浏览器和 HTML 解 ...

  9. ASP.NET Core MVC四种枚举绑定方式

    前言 本节我们来讲讲在ASP.NET Core MVC又为我们提供了哪些方便,之前我们探讨过在ASP.NET MVC中下拉框绑定方式,这节我们来再来重点看看枚举绑定的方式,充分实现你所能想到的场景,满 ...

随机推荐

  1. spark优化之优化数据结构

    概序: 要减少内存的消耗,除了使用高效的序列化类库以外,还有一个很重要的事情,就是优化数据结构.从而避免Java语法特性中所导致的额外内存的开销,比如基于指针的Java数据结构,以及包装类型. 有一个 ...

  2. ..c++中用c语言的输入法

    题目: 竞选时,要求选民在n个候选人中选择,n个人的名字为 A,B,C,D--连续n个大写字母,如果选择n个人名字之外的人员,则为废票.   统计时以输入'#'为结束标记.请按候选人的得票数目从大到小 ...

  3. 目前用到最全的datagrid(easyui)

    包含checkbox.复合表头.多行可编辑单元格.combobox单元格,就差上次做的table中每行中的关联检索combobox单元格了.目前已修改为单行编辑,多行编辑时的check有问题 $(&q ...

  4. poj1270 拓扑序(DFS)

    题意:给出将会出现的多个字母,并紧接着给出一部分字母的大小关系,要求按照字典序从小到大输出所有符合上述关系的排列. 拓扑序,由于需要输出所有排列,所以需要使用 dfs ,只要点从小到大遍历就可以实现字 ...

  5. Oracle学习系列3

    Oracle学习系列3 ************************************************************************************ 多表查 ...

  6. Data Pump(数据抽取)介绍

    从10g开始,Oracle提供更高效的Data Pump(即expdp/impdp)来进行数据的导入和导出,老的exp/imp还可以用,但已经不建议使用.注意:expdp/impdp和exp/imp之 ...

  7. UIview 学习与自定义--ios

    UIView *view1=[[UIView alloc] initWithFrame:CGRectMake(50, 50, 100, 100)]; view1.backgroundColor=[UI ...

  8. mysql中的semi-join

    1. 背景介绍 什么是semi-join? 所谓的semi-join是指semi-join子查询. 当一张表在另一张表找到匹配的记录之后,半连接(semi-jion)返回第一张表中的记录.与条件连接相 ...

  9. SaaS、PaaS和IaaS

    •SaaS(软件即服务) •PaaS(平台即服务) •IaaS(基础架构即服务)

  10. unity, 由5.2.1f1升级到5.3.5f1,2d物理不正常解法

    由5.2.1f1升级到5.3.5f1,物理不正常. 最后发现问题出在我的游戏中的下面一段代码:   Vector2 targetPosition=...;   Vector2 targetVeloci ...