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

原创 2006年06月08日 20:29:00

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"
     */
    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的思想。

"Berkeley DB"数据库的优点和不足之处

Sleepycat软件公司出品的Berkeley DB是一种在特定的数据管理应用程序中广泛使用的数据库系统,在世界范围内有超过两亿的用户支持.许多世界知名的厂商,像Amazon, AOL, Briti...
  • hit_hlj_sgy
  • hit_hlj_sgy
  • 2013年09月17日 17:34
  • 1938

Berkeley DB基础教程

一、Berkeley DB的介绍 (1)Berkeley DB是一个嵌入式数据库,它适合于管理海量的、简单的数据。如Google使用其来保存账户信息,Heritrix用其来保存froniter. (...
  • jediael_lu
  • jediael_lu
  • 2014年05月29日 15:21
  • 14208

Redis连接 db,dbIndex参数-- Redis配置多个数据库

一台服务器上都快开启200个redis实例了,看着就崩溃了。这么做无非就是想让不同类型的数据属于不同的应用程序而彼此分开。 那么,redis有没有什么方法使不同的应用程序数据彼此分开同时又存储在...
  • lsm135
  • lsm135
  • 2016年10月27日 14:08
  • 8986

DB Migration 数据库版本管理工具 学习笔记

一.什么是DB Migrations 二.DB Migratoins的使用 三.补充(异常)   一.什么是DB Migrations     DB Migrations是一个开源的用于DB...
  • u014077165
  • u014077165
  • 2015年05月24日 22:45
  • 1427

java操作 mongo DB 数据库例子

package com.tompig.ljc; import java.net.UnknownHostException; import java.util.ArrayList; impor...
  • jintianhen1
  • jintianhen1
  • 2014年09月17日 10:46
  • 832

将Berkeley DB基本数据库操作封装成类

Berkeley DB是一个嵌入式数据库,适合于管理海量的、简单的数据。 键值对(key/value)数据存储方式使Berkeley DB用来进行数据库管理的基础,每个key/value构成一条记录...
  • zgljl2012
  • zgljl2012
  • 2015年03月03日 17:46
  • 999

图解MyEclipse用DB Browser连接四种数据库

所用到的jar包下载: http://pan.baidu.com/s/1skFeGVj 一 连接Oracle 在MyEclipse中打开DB Browser;右键,新建; ...
  • bcbobo21cn
  • bcbobo21cn
  • 2016年08月28日 23:12
  • 4051

【Java数据库连接类】封装数据库操作的连接类DBConnection

在项目开发中,操作数据库需要数据库连接对象,通过此公共类能方便的获得数据库连接对象。...
  • xiongwt
  • xiongwt
  • 2016年03月12日 16:09
  • 965

java log4j日志 写入数据库

因帮朋友log4j日志 写入数据库,写了这个 log4j.properties ----------------------------------------- #可以设置级别:debug>i...
  • zhanglu0223
  • zhanglu0223
  • 2015年09月23日 15:11
  • 3420

java操作redis数据库实例(redis集群)

1、配置redis集群 [html] view plain copy  print? xml version="1.0" encoding="UTF-8"...
  • younger_z
  • younger_z
  • 2016年05月10日 21:27
  • 2403
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:WebLogic运用DB的Java控件访问数据库
举报原因:
原因补充:

(最多只允许输入30个字)