Chinaunix首页 | 论坛 | 博客
  • 博客访问: 513057
  • 博文数量: 1496
  • 博客积分: 79800
  • 博客等级: 大将
  • 技术积分: 9940
  • 用 户 组: 普通用户
  • 注册时间: 2008-09-09 13:22
文章分类

全部博文(1496)

文章存档

2011年(1)

2008年(1495)

我的朋友

分类:

2008-09-09 17:23:43

草木瓜  2006-6-8

一、方法

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

二、建立连接池,数据源

   配置config.xml文件,这里用的是WebLogic自带的E:\bea\weblogic81\samples\domains\workshop
   的cgServer。
  
          LoginDelaySeconds="1" MaxCapacity="20" Name="liwei"
        PasswordEncrypted="{3DES}WBNJPYUOAvE=" Properties="user=liwei"
        Targets="cgServer" URL="jdbc:oracle:thin:@localhost:1521:wincn"/>
   
   
    或者 工具->WebLogic Server->数据源查看器->新建数据源 步骤比较简单,主要输入对应参数:
    DriverName="oracle.jdbc.driver.Driver"
    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;
    }
}

[1]  

【责编:Peng】

--------------------next---------------------

阅读(170) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~