都不知道怎么写,反正这个东西在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;
}