WebLogic运用DB的Java控件访问数据库

2008-02-23 09:12:53来源:互联网 阅读 ()

新老客户大回馈,云服务器低至5折

WebLogic运用DB的Java控件访问数据库

草木瓜 2006-6-8

一、方法

WebLogic页面与数据通信时,一般采用Java控件直接访问数据连接池,数据的直接操作都定义在
Java控件中,页面流做为数据的逻辑处理单元,普通页面做为显示层。可以看出WebLogic这个方法是
典型的三层结构,数据层(Java控件),业务逻辑层(页面流),显示层(页面)

二、建立连接池,数据源

配置config.XML文件,这里用的是WebLogic自带的E:\bea\weblogic81\samples\domains\workshop
的cgServer。

<JDBCConnectionPool DriverName="Oracle.jdbc.driver.OracleDriver"
LoginDelaySeconds="1" MaxCapacity="20" Name="liwei"
PasswordEncrypted="{3DES}WBNJPYUOAvE=" Properties="user=liwei"
Targets="cgServer" URL="jdbc:oracle:thin:@localhost:1521:wincn"/>
<JDBCTxDataSource JNDIName="liwei" Name="liwei" PoolName="liwei" Targets="cgServer"/>

或者 工具->WebLogic Server->数据源查看器->新建数据源 步骤比较简单,主要输入对应参数:
DriverName="oracle.jdbc.driver.OracleDriver"
URL="jdbc:oracle:thin:@localhost:1521:wincn"
然后用户名密码即可。

以上内容可参看《Weblogic中JSP连接数据库》一文

三、相关页面

Test\TestWeb\recordset\RecordsetController.jpf
Test\TestWeb\recordset\index.jsp
Test\TestWeb\recordset\test.jcx java控件

四、数据库

CREATE TABLE TEST(
A VARCHAR2(10),
B VARCHAR2(10),
C VARCHAR2(10),
D VARCHAR2(10)
)

五、数据层(JAVA控件)

本次示例使用tblTest自定义静态类实现返回数据集。(还可以使用netui:gird RecordSet实现,参见自带示例)
其中update方法与insert方法十分类似,故未提供具体的实现代码。
数据层并没有什么复杂之处,只是对逻辑层(页面流)提供足够的数据操作接口。tblTest自定义的静态类
是完成数据传递必不可少的环节。

Test\TestWeb\recordset\test.jcx 全代码

package recordset;

import com.bea.control.*;
import java.sql.SQLException;

/*
* @jc:connection data-source-jndi-name="liwei"
*/
public interface test extends DatabaseControl, com.bea.control.ControlExtension
{
/**
* @jc:sql statement::
* INSERT INTO TEST (A,B,C,D)
* VALUES ({_A},{_B},{_C},{_D})
* ::
*/
public int insert( String _A, String _B,String _C,String _D );

/**
* @jc:sql statement::
* UPDATE TEST SET B = {_B} ,C = {_C} ,D = {_D} WHERE A = {_A}
* ::
*/
public int update( String _A, String _B,String _C,String _D );

/**
* @jc:sql statement::
* DELETE TEST WHERE A = {_A}
* ::
*/
public int delete( String _A );


/**
* @jc:sql statement::
* SELECT * FROM TEST WHERE A = {_A}
* ::
*/
public tblTest select( String _A );

/**
* @jc:sql statement::
* SELECT * FROM TEST
* ::
*/
public tblTest[] selectAll();

public static class tblTest implements java.io.Serializable
{
public String A;
public String B;
public String C;
public String D;
}
}

六、逻辑层(页面流)

Test\TestWeb\recordset\RecordsetController.jpf 主要代码,省略了自动生成部分

public class RecordsetController extends PageFlowController
{
/*
*
* @common:control
*/
private test recTest; //定义数据接口
private test.tblTest[] recNew; //定义数据集

//因为示例连接的是英文数据库,会存在乱码问题,下面是转码的函数,这也充分
//说明了,逻辑层在处理数据的关键所在。
private String getGBString(String strIn)
{
try
{
byte[] tmPByte=strIn.getBytes("ISO8859-1");
return new String(tmpByte,"gb2312");
}
catch(Exception e)
{
return "";
}
}

//返回全记录,调用recTest的selectAll,接口函数
public test.tblTest[] getAll()
{
recNew=recTest.selectAll();
int i;
for(i=0;i<recNew.length;i )
{
recNew[i].A=getGBString(recNew[i].A);
recNew[i].B=getGBString(recNew[i].B);
recNew[i].C=getGBString(recNew[i].C);
recNew[i].D=getGBString(recNew[i].D);
}
return recNew;
}



//添加数据,这时通过页面传递的参数值,调用接口Add数据
/**
* @jpf:action
* @jpf:forward name="success" path="index.jsp"

标签:

版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有

上一篇:newxy struts实现零java代码或极少java代码开发以数据为中心的we

下一篇:Java中文解决方案一览