[JSF]关于VWP里的DataProvider

       都不知道怎么写,反正这个东西在VWP是操作数据库的核心。这几天想把原来开发的“账本”编一个类来专门操作数据库,但是总不成功。就在刚才才发现问题。就是忘了初始化数据库,也就是连接数据库,把行集放到DataProvider里面。因为原来操作数据库是在当前页,DataProvider的初始化也在当前页;而现在改到一个类里面了,就要在操作前对要操作的数据库“初始化”。也就是要在操作方法的try{}里面加入_init();来初始化数据库,之后就可以对行集进行操作了。之前出错的原因就是没在自编的类里面初始化,行集也就是空的,无法操作。

/*初始化,连接数据库,取得行集*/

private void _init() throws Exception {
        mainRowSet.setDataSourceName("java:comp/env/jdbc/account");
        mainRowSet.setCommand("SELECT * FROM main");
        mainRowSet.setTableName("main");
        mainDataProvider.setCachedRowSet((javax.sql.rowset.CachedRowSet)getValue("#{Tdb.mainRowSet}"));
       }

/*一个测试,看是否连接到数据库并取得行集了*/

 public String g(){
        String str="";
       
         try {
             _init();
       if( mainDataProvider.canAppendRow()) //看是否能添加行。
      str = "YES";
        else str = "No";
        }
       catch (Exception ex) {
            log("Error Description", ex);
          error(ex.getMessage());
       }
       return str;
    }

private CachedRowSetDataProvider mainDataProvider = new CachedRowSetDataProvider();

    public CachedRowSetDataProvider getMainDataProvider() {
        return mainDataProvider;
    }

    public void setMainDataProvider(CachedRowSetDataProvider crsdp) {
        this.mainDataProvider = crsdp;
    }

    private CachedRowSetXImpl mainRowSet = new CachedRowSetXImpl();

    public CachedRowSetXImpl getMainRowSet() {
        return mainRowSet;
    }

    public void setMainRowSet(CachedRowSetXImpl crsxi) {
        this.mainRowSet = crsxi;
    }

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值