王朝网络
分享
 
 
 

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

王朝java/jsp·作者佚名  2008-05-31
宽屏版  字体: |||超大  

草木瓜 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"

*/

public Forward add()

{

recTest.insert(this.getRequest().getParameter("a"), this.getRequest().getParameter("b"),this.getRequest().getParameter("c"),this.getRequest().getParameter("d"));

return new Forward( "success" );

}

//删除数据

/**

* @jpf:action

* @jpf:forward name="success" path="index.jsp"

*/

public Forward delete()

{

recTest.delete(this.getRequest().getParameter("ToDelete"));

return new Forward( "success");

}

/**

* 此方法代表进入页面流的入口

* @jpf:action

* @jpf:forward name="success" path="index.jsp"

*/

protected Forward begin()

{

return new Forward("success");

}

}

七、显示层(页面)

Test\TestWeb\recordset\index.jsp 最外层显示,查看下面完全代码时,可以看到netui控件的极大

灵活性。

技术难点并不多,这里使用的是netui-data:repeater,重复获取记录集数据。

<body>

<table border=1>

<tr>

<td width="100" class="header-text">A</td>

<td width="100" class="header-text">B</td>

<td width="100" class="header-text">C</td>

<td width="100" class="header-text">D</td>

</tr>

<netui-data:repeater dataSource="{pageFlow.all}">

<netui-data:repeaterHeader> </netui-data:repeaterHeader>

<netui-data:repeaterItem>

<tr>

<td width="100" class="row-text"><a href="#" onclick="window.alert('<netui:content value='{container.item.A}-{container.item.B}-{container.item.C}-{container.item.D}'/>')"><netui:label value="{container.item.A}"/></a></td>

<td width="100" class="row-text"><netui:label value="{container.item.B}"/></td>

<td width="100" class="row-text"><netui:label value="{container.item.C}"/></td>

<td width="100" class="row-text"><netui:label value="{container.item.D}"/></td>

<td>

<netui:anchor action="delete" onClick="return(window.confirm('Del?'))">

<netui:parameter name="ToDelete" value="{container.item.A}"/>

Delete

</netui:anchor>

</td>

</tr>

</netui-data:repeaterItem>

<netui-data:repeaterFooter> </netui-data:repeaterFooter>

</netui-data:repeater>

</table>

<hr>

<netui:form action="add" >

A:<input type="text" name="a"/><br>

B:<input type="text" name="b"/><br>

C:<input type="text" name="c"/><br>

D:<input type="text" name="d"/><br>

<input type="submit" value="add">

</netui:form>

</body>

八、小结

以前对java的了解为0,因项目迫切需要适当的研究下WebLogic,作为入门级的选手就能感受到WebLogic魅力

的一二。清楚的层次非常便于组织项目的架构。页面流在Web开发过程可为核心,结合表示层的netui控件,将

大量脚本可以化为简单轻松的面向对象的java语句。不管是前面提到的树形,还是本文的数据,随意而不零乱

却是有机的整体。强!

感觉需要选本书系统的学习一下WebLogic的思想。

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
>>返回首页<<
推荐阅读
 
 
频道精选
 
静静地坐在废墟上,四周的荒凉一望无际,忽然觉得,凄凉也很美
© 2005- 王朝网络 版权所有