WebLogic运用DB的Java控件会见数据库
当前位置:以往代写 > JAVA 教程 >WebLogic运用DB的Java控件会见数据库
2019-06-14

WebLogic运用DB的Java控件会见数据库

WebLogic运用DB的Java控件会见数据库

副标题#e#

一、要领 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;
}
}


#p#副标题#e#

六、逻辑层(页面流)

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");
}

#p#分页标题#e#

/**
* 此要领代表进入页面流的进口
* @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的思想。

    关键字:

在线提交作业