亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

WebLogic運用DB的Java控件訪問數據庫

2019-11-17 05:55:42
字體:
來源:轉載
供稿:網友

草木瓜  2006-6-8 一、方法  WebLogic頁面與數據通信時,一般采用java控件直接訪問數據連接池,數據的直接操作都定義在
Java控件中,頁面流做為數據的邏輯處理單元,普通頁面做為顯示層??梢钥闯鯳ebLogic這個方法是
典型的三層結構,數據層(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="         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的思想。



發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
成人动漫网站在线观看| 国产精品99久久99久久久二8| 国产精品视频一区国模私拍| 久久人人看视频| 九色91av视频| 欧美日韩国产综合视频在线观看中文| 亚洲自拍小视频免费观看| 九九热这里只有在线精品视| 欧美高清电影在线看| 国产亚洲精品一区二区| 久久久女人电视剧免费播放下载| 国产亚洲精品久久久| 欧美精品一区二区免费| 日本国产高清不卡| 亚洲精品美女免费| 亚洲国产精品久久| 国产精品高潮粉嫩av| 国产成人精品在线视频| 91人成网站www| 成人黄色免费网站在线观看| 成人黄色免费网站在线观看| 国产精品无码专区在线观看| 国产原创欧美精品| 亚洲在线观看视频网站| 国模吧一区二区| 亚洲自拍高清视频网站| 欧美一级片久久久久久久| 国产精品v片在线观看不卡| 欧美精品videossex88| 激情久久av一区av二区av三区| 8090成年在线看片午夜| 欧美在线视频免费| 中日韩美女免费视频网址在线观看| 午夜精品一区二区三区在线视频| 国产欧美精品在线播放| 亚洲美女又黄又爽在线观看| 日韩av免费一区| 最新69国产成人精品视频免费| 亚洲第一精品久久忘忧草社区| 4444欧美成人kkkk| 精品国产乱码久久久久久虫虫漫画| 亚洲一区二区三区四区在线播放| 国产自产女人91一区在线观看| 4388成人网| 亚洲欧洲日韩国产| 欧美成人第一页| 中文字幕亚洲第一| 亚洲跨种族黑人xxx| 欧美精品国产精品日韩精品| 欧洲成人在线观看| 亚洲国产精彩中文乱码av在线播放| 久久噜噜噜精品国产亚洲综合| 最近2019中文字幕第三页视频| 欧美激情中文字幕乱码免费| 91精品国产综合久久香蕉的用户体验| 国产精品91在线观看| 欧美亚洲在线播放| 亚州国产精品久久久| 午夜精品久久久久久久久久久久| 国产精品美女久久久免费| 国产在线观看一区二区三区| 欧洲永久精品大片ww免费漫画| 日韩中文字幕视频在线观看| 色一情一乱一区二区| 国产亚洲日本欧美韩国| 亚洲电影免费观看高清完整版在线| 在线不卡国产精品| 国模私拍一区二区三区| 亚洲午夜av久久乱码| 日本亚洲欧洲色α| 超碰日本道色综合久久综合| 色先锋久久影院av| 国自产精品手机在线观看视频| 亚洲视频一区二区三区| 久久久www成人免费精品| 欧美成人免费在线观看| 国产国语videosex另类| 在线观看免费高清视频97| 欧美精品成人91久久久久久久| 日韩电影免费在线观看中文字幕| 欧美日韩国产成人在线观看| 欧美视频国产精品| 黑人巨大精品欧美一区免费视频| 国产精品 欧美在线| 久久久av亚洲男天堂| 精品视频久久久久久| 国产视频自拍一区| 57pao国产成人免费| 91精品视频在线免费观看| 51色欧美片视频在线观看| 国产一区二区三区久久精品| 欧美理论片在线观看| 亚洲欧美综合v| 欧美美女18p| 久久精品久久久久久国产 免费| 日韩精品丝袜在线| 亚洲精品日韩av| 国产午夜精品免费一区二区三区| 92版电视剧仙鹤神针在线观看| 精品久久中文字幕久久av| 国产精品久久久久av免费| 在线一区二区日韩| 日韩久久精品电影| 日韩精品免费在线观看| 欧美大学生性色视频| 精品久久久久久久久久久久久久| 亚洲精品国产精品乱码不99按摩| 久久99亚洲精品| 97欧美精品一区二区三区| 亚洲精品视频在线播放| 日韩在线精品视频| 欧美日韩亚洲精品一区二区三区| 国产精品电影久久久久电影网| 国产欧美最新羞羞视频在线观看| 成人国产精品免费视频| 97在线视频国产| 久久久久www| 日韩精品免费综合视频在线播放| 日韩中文字幕在线看| 欧美性做爰毛片| 日韩在线视频观看正片免费网站| 国产一区二区三区在线播放免费观看| 精品国产拍在线观看| 97视频免费观看| 91天堂在线视频| 欧美中在线观看| 欧美另类69精品久久久久9999| 亚洲国产成人在线播放| 欧美在线观看网址综合| 久久影视三级福利片| 成人国产精品久久久| 少妇av一区二区三区| 日韩免费在线免费观看| 成人在线一区二区| 色播久久人人爽人人爽人人片视av| 久久久久一本一区二区青青蜜月| 久久男人资源视频| 懂色av一区二区三区| 奇米一区二区三区四区久久| 精品亚洲夜色av98在线观看| 成人精品网站在线观看| 高清一区二区三区四区五区| 久久天天躁狠狠躁夜夜av| 97免费中文视频在线观看| 亚洲福利在线视频| 欧美乱人伦中文字幕在线| 97精品久久久| 欧美午夜影院在线视频| 亚洲精品一区av在线播放| 精品视频在线播放色网色视频| 日韩少妇与小伙激情| 日韩电影在线观看永久视频免费网站| 久久免费视频在线| 一区二区三区四区在线观看视频| 亚洲视频一区二区三区| 国产视频久久久| 中文字幕欧美精品在线| 欧美乱大交做爰xxxⅹ性3| 日韩福利伦理影院免费| 最新69国产成人精品视频免费| 久久久久久97| 精品偷拍一区二区三区在线看| 成人免费视频xnxx.com| 国产精品18久久久久久麻辣|