![]() ![]() |
|
WebLogic运用DB的Java控件访问数据库 | |
作者:佚名 文章来源:不详 点击数 更新时间:2008/4/18 14:42:09 文章录入:杜斌 责任编辑:杜斌 | |
|
|
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.jcxjava控件 四、数据库 CREATE TABLE TEST( AVARCHAR2(10), BVARCHAR2(10), CVARCHAR2(10), DVARCHAR2(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; } }共2页。 六、逻辑层(页面流) 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> |
|
![]() ![]() |