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

2016-02-19 20:05 28 1 收藏

只要你有一台电脑或者手机,都能关注图老师为大家精心推荐的WebLogic运用DB的Java控件访问数据库,手机电脑控们准备好了吗?一起看过来吧!

【 tulaoshi.com - 编程语言 】

  草木瓜  2006-6-8 一、方法  WebLogic页面与数据通信时,一般采用Java控件直接访问数据连接池,数据的直接操作都定义在
  Java控件中,页面流做为数据的逻辑处理单元,普通页面做为显示层。可以看出WebLogic这个方法是
  典型的三层结构,数据层(Java控件),业务逻辑层(页面流),显示层(页面)

  二、建立连接池,数据源

     配置config.XML文件,这里用的是WebLogic自带的E:eaweblogic81samplesdomainsworkshop
     的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连接数据库》一文
     
  三、相关页面

(本文来源于图老师网站,更多请访问http://www.tulaoshi.com/bianchengyuyan/)

    TestTestWebecordsetRecordsetController.jpf
    TestTestWebecordsetindex.jsp
    TestTestWebecordsetest.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自定义的静态类
  
   是完成数据传递必不可少的环节。
   
    TestTestWebecordsetest.jcx 全代码
   
  package recordset;

(本文来源于图老师网站,更多请访问http://www.tulaoshi.com/bianchengyuyan/)

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

  

  六、逻辑层(页面流)
    
   TestTestWebecordsetRecordsetController.jpf 主要代码,省略了自动生成部分

!-- frame contents --!-- /frame contents --

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

  
  七、显示层(页面)

   TestTestWebecordsetindex.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的思想。

  


来源:http://www.tulaoshi.com/n/20160219/1622730.html

延伸阅读
标签: Java JAVA基础
<%@ page session="false" %> <%@ page import="java.sql.*"%> <%@ page import="java.util.*"%> <html> <head> </head> <body> <% String url="jdbc:db2:ch"; //此格式为jdbc:子协议:子名称,其中ch是数据库名 String user="db2inst1"; //数据库连接者ID String password="db2inst1"; //数据...
1、用数据库软件(如:mysql)创建数据库,在数据库注册时用到的数据库名则为刚刚创建的数据 库,若为数据源名,则需ODBC配置。 2、将驱动程序放在D:\Tomcat 5.5\common\lib或相应的开发工具的lib下, 对D:\Tomcat 5.5\conf\web.xml修改,打开web.xml,在/web-app的前面添加以下内容: resource-ref descriptionDB Con...
1.尽量使用事务处理更新数据库 VB的事务处理包括以BeginTrans开始,以CommitTrans或Rollback结尾的多条数据库操作指令。事务处理除了能很好的保证数据库的完整性以外,同时能大大提高数据库批量更新的效率。这是因为如果数据库更新操作没有使用事务处理,则每次Update操作都会引起数据库写盘一次。使用事务处理后,更新只在内存缓冲区内进行...
using System; using System.Data; using System.Data.OleDb; using System.Collections; namespace XLang.VideoOnline.Framework.Database.Access { /// /// Summary description for ACCESS_DataViewsCollection. /// public class DataViewsCollection { private Database.Access.DataView[] _views; private int _count; pub...
关于如何取得数据库架构信息,对于取得SQL Server和Oracal的数据库结构可能比较简单,方法也比较多。这里整理了一个对于所有能用ADO.Net链接的数据库(比如Access,db4格式的dbf自由表等)都通用的方法 1、首先就是链接各种数据库的链接字符串,都是用ADO.Net,命名空间是:using System.Data.OleDb;用几种数据库举个例子,需要其他的数据库链...

经验教程

460

收藏

45
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部