麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 學院 > 開發(fā)設計 > 正文

WebLogic運用DB的Java控件訪問數(shù)據(jù)庫

2019-11-17 05:55:42
字體:
來源:轉載
供稿:網(wǎng)友

草木瓜  2006-6-8 一、方法  WebLogic頁面與數(shù)據(jù)通信時,一般采用java控件直接訪問數(shù)據(jù)連接池,數(shù)據(jù)的直接操作都定義在
Java控件中,頁面流做為數(shù)據(jù)的邏輯處理單元,普通頁面做為顯示層。可以看出WebLogic這個方法是
典型的三層結構,數(shù)據(jù)層(Java控件),業(yè)務邏輯層(頁面流),顯示層(頁面)

二、建立連接池,數(shù)據(jù)源

   配置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="         Targets="cgServer" URL="jdbc:oracle:thin:@localhost:1521:wincn"/>
    <JDBCTxDataSource JNDIName="liwei" Name="liwei" PoolName="liwei" Targets="cgServer"/>
   
    或者 工具->WebLogic Server->數(shù)據(jù)源查看器->新建數(shù)據(jù)源 步驟比較簡單,主要輸入對應參數(shù):
    DriverName="oracle.jdbc.driver.OracleDriver"
    URL="jdbc:oracle:thin:@localhost:1521:wincn"
   然后用戶名密碼即可。
   
   以上內容可參看《Weblogic中
jsp連接數(shù)據(jù)庫》一文
   
三、相關頁面

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

四、數(shù)據(jù)庫

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

五、數(shù)據(jù)層(JAVA控件)

    本次示例使用tblTest自定義靜態(tài)類實現(xiàn)返回數(shù)據(jù)集。(還可以使用netui:gird+RecordSet實現(xiàn),參見自帶示例)
其中update方法與insert方法十分類似,故未提供具體的實現(xiàn)代碼。
 數(shù)據(jù)層并沒有什么復雜之處,只是對邏輯層(頁面流)提供足夠的數(shù)據(jù)操作接口。tblTest自定義的靜態(tài)類

是完成數(shù)據(jù)傳遞必不可少的環(huán)節(jié)。
 
  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;       //定義數(shù)據(jù)接口
    private test.tblTest[] recNew;  //定義數(shù)據(jù)集

   
    //因為示例連接的是英文數(shù)據(jù)庫,會存在亂碼問題,下面是轉碼的函數(shù),這也充分
    //說明了,邏輯層在處理數(shù)據(jù)的要害所在。
    private String getGBString(String strIn)
    {
        try
        {  
            byte[] tmpByte=strIn.getBytes("ISO8859-1");  
            return new String(tmpByte,"gb2312");
        }
        catch(Exception e)
        {
            return "";
        }
    }

  //返回全記錄,調用recTest的selectAll,接口函數(shù)
    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;
    }
   
   
   
    //添加數(shù)據(jù),這時通過頁面?zhèn)鬟f的參數(shù)值,調用接口Add數(shù)據(jù)
     /**
     * @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" );
    }
 
   //刪除數(shù)據(jù)
    /**
     * @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,重復獲取記錄集數(shù)據(jù)。
 
    <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,因項目迫切需要適當?shù)难芯肯耊ebLogic,作為入門級的選手就能感受到WebLogic魅力
的一二。清楚的層次非常便于組織項目的架構。頁面流在Web開發(fā)過程可為核心,結合表示層的netui控件,將
大量腳本可以化為簡單輕松的面向對象的java語句。不管是前面提到的樹形,還是本文的數(shù)據(jù),隨意而不零亂
卻是有機的整體。強!
 感覺需要選本書系統(tǒng)的學習一下WebLogic的思想。



發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 欧美一区在线观看视频 | 红杏亚洲影院一区二区三区 | 国产精品久久久久久久久久东京 | 欧美伦理一区二区 | 香蕉久久久久 | 久久久久久久久久久久久国产精品 | 99爱在线免费观看 | 看片一区二区三区 | cosplay裸体福利写真 | h视频在线免费观看 | 国产精品久久久久久久久久久天堂 | 国产一区毛片 | 一级黄色影院 | 亚洲欧美不卡视频 | 狼人狠狠干| 午夜色片 | 九艹在线 | 免费一区在线 | 一级黄色性感片 | 欧美成人黄色片 | 国产精品午夜一区 | 国产黄色录像片 | 72pao成人国产永久免费视频 | 精品国产91久久久久 | 蜜桃视频在线免费观看 | 污视频在线免费播放 | 久久草在线视频国产 | 成人一级视频在线观看 | 欧产日产国产精品v | 91麻豆精品国产91久久久无需广告 | 精品国产乱码久久久久久丨区2区 | 欧美激情精品久久久久久黑人 | 性爱免费在线视频 | 国产亚洲精品一区二区三区 | 青青草成人av | 粉嫩蜜桃麻豆免费大片 | 999久久国精品免费观看网站 | 毛片视频网址 | 亚洲国产精品久久久久久久久久久 | 欧美激情精品久久久久久黑人 | 色97在线|