在业务层AMImpl对VO进行查询主要有两种方式:
1、设计时附上where子句
设计时在VO视图的edit query窗口,输入where子句,设置bind variabs
2、运行时附加where子句
String whereClause = ”name = :bind_name";//查询子句
调用VO的setWhereClause(),vo.setWhereClause(whereClause); // 附加where子句
调用VO的defineNamedWhereClauseParam(“bind_name", null, null);//定义绑定变量(bind_name)
调用VO的setNamedWhereClauseParam("bind_name","harlen");//设置绑定变量的值
示例:
public void testQuery(){
UserVOImpl user = am.getUserVO1();
user.setWhereClause("Sso= :bind_sso");
user.defineNamedWhereClauseParam("bind_sso", null, null);
user.setNamedWhereClauseParam("bind_sso", "test@test.com");
user.executeQuery();
int id = Integer.parseInt(user.next().getAttribute("UserId").toString());
Key key = new Key(new Object[] {id});
Row[] row = user.findByKey(key, -1); //-1:fetch all rows
System.out.println(row.length);
}
原文:http://www.cnblogs.com/hzorac/p/4277717.html