-
Notifications
You must be signed in to change notification settings - Fork 60
4、分页、查询部分字段原来如此简单
Bee edited this page Jun 30, 2020
·
1 revision
Bee简单易用:单表操作、多表关联操作,可以不用写sql,极少语句就可以完成SQL操作;10分钟即可学会使用。 Bee功能强大:复杂查询也支持向对象方式,分页查询性能更高,一级缓存即可支持个性化优化。高级需求,还可以方便自定义SQL语句。
1.1 单表查询的分页
SuidRich接口提供方法:
public List select(T entity,intstart,intsize);
最终语句会转化为原生的分页语句,执行效率更高。
具体实例(DB以mysql数据库为例).
public static void main(String[] args) {
SuidRich suidRich=BeeFactory.getHoneyFactory().getSuidRich();
Orders orders1 = new Orders();
List<Orders> list1 = suidRich.select(orders1,0,2); //分页,查询前两条记录
// List<Orders> list1 = suidRich.select(orders1,"id,userid,name",0,2); //分页,查询前两条记录且只查询部分字段
for (int i = 0; i < list1.size(); i++) {
Logger.info(list1.get(i).toString());
}
}
2020-05-04 11:35:06 INFO [Bee]select(entity,start,size) SQL:
selectid,userid,name,total,createtime,remark,sequence,abc,updatetime from orders limit 0,2
2020-05-04 11:35:06 INFOOrders[id=100001,userid=bee,name=Bee(ORM Framework),total=100.00,createtime=null,remark=new2,sequence=,abc=null,updatetime=2020-05-0408:50:46.0]
2020-05-04 11:35:06 INFOOrders[id=100002,userid=bee,name=null,total=100.00,createtime=null,remark=new2,sequence=,abc=null,updatetime=2020-04-2222:00:12.0]
1.2 复杂查询的分页
Suid suid = BeeFactory.getHoneyFactory().getSuid();
Orders orders = new Orders();
orders.setName("Bee(ORM Framework)"); //等于的条件,会默认转换
orders.setTotal(new BigDecimal("100")); //不会再处理.因为between已有用
Condition condition=new ConditionImpl();
condition
.op("userid", Op.like, "bee%") //模糊查询
.between("total", 90, 100) //total字段的范围查询
.between("createtime","2020-03-01","2020-03-03")
.orderBy("userid",OrderType.ASC) //排序
.start(0).size(10) //分页
;
List<Orders> list2 = suid.select(orders, condition);
for (int i = 0; i < list2.size(); i++) {
Logger.info(list2.get(i).toString());
}
[Bee] select SQL:
selectid,userid,name,total,createtime,remark,sequence,abc,updatetime from orderswhere name=? and userid like ? and total between ? and ? and createtime between? and ? order by userid asc limit 0,10 [values]: Bee(ORMFramework),bee%,90,100,2020-03-01,2020-03-03
Orders[id=100001,userid=bee,name=Bee(ORMFramework),total=95.01,createtime=2020-03-0211:29:28.0,remark=test,sequence=12345601,abc=test1,updatetime=2020-03-0216:34:19.0]
Orders[id=100002,userid=bee,name=Bee(ORMFramework),total=96.01,createtime=2020-03-0211:29:28.0,remark=test,sequence=12345602,abc=test2,updatetime=2020-03-0216:34:19.0]
Orders[id=100003,userid=bee,name=Bee(ORMFramework),total=97.01,createtime=2020-03-0211:29:28.0,remark=test,sequence=12345603,abc=test3,updatetime=2020-03-02 16:34:19.0]
1.3 自定义语句的分页
在PreparedSql接口中,提供的以下方法,都有分页功能,最终都是转化为原生的SQL分页语句。Bee的分页功能,使用简单,分页查询性能更高。
public<T> List<T> select(String sql,T returnType,ObjectpreValues[],intstart,intsize);
public <T> List<T> select(String sqlStr,T entity,Map<String,Object> parameterMap,intstart,intsize);
public List<String[]>select(String sql,ObjectpreValues[],intstart,intsize);
public List<String[]>select(String sqlStr,Map<String,Object>map,intstart,intsize);
public <T> List<T>selectSomeField(String sql,T returnType,Object preValues[],intstart,intsize);
public <T> List<T>selectSomeField(String sqlStr,T entity,Map<String,Object>parameterMap,intstart,intsize);
public StringselectJson(String sql,ObjectpreValues[],intstart,intsize);
public StringselectJson(String sqlStr,Map<String,Object>map,intstart,intsize);
只查询需要的字段,不查多余字段,Bee提供了简单易用的API。
2.1 利用SuidRich接口查询部分字段
SuidRich接口中,提供了以下三个方法,可以通过参数selectFields指定需要查询的字段(多个用逗号隔开)。
public <T>List<T> select(T entity,String selectFields);
public <T> List<T>select(T entity,String selectFields,intstart,intsize);
public <T>List<String[]> selectString(T entity,String selectFields);
使用实例:
// List<Orders> list1 = suidRich.select(orders1,0,2); //分页,查询前两条记录
//分页,查询前两条记录且只查询部分字段
List<Orders> list1 = suidRich.select(orders1,"id,userid,name",0,2);
得到的sql语句:
select id, userid, name from orders limit 0,2
可以看出,只返回了我们需要的字段。需要注意的是,用一个Javabean模型接收数据时,没返回的数据是null的。用List<String[]> selectString(T entity,String selectFields)则不会有这种情况,它只会将返回的字段转成字符串。
2.2 利用PreparedSql接口查询部分字段
在PreparedSql接口中,提供的以下方法,都有分页功能,且可以只查询部分字段。
public <T>List<T> selectSomeField(String sql,T returnType,Object preValues[],intstart,int size);
public <T> List<T> selectSomeField(String sqlStr,Tentity,Map<String,Object> paramete