bboss持久层分页接口使用示例

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS PostgreSQL,集群系列 2核4GB
简介: bboss持久层快速上手 bboss持久层分页接口比较有特色,提供了四种Style的分页接口: 第一种Style 根据sql语句直接分页,这种风格是bboss 3.6.0及之前版本一直沿用的接口 第二种Style 根据sql语句和外部传入的总记录数进行分页,这是bboss 3.
bboss持久层快速上手
bboss持久层分页接口比较有特色,提供了四种Style的分页接口:
第一种Style 根据sql语句直接分页,这种风格是bboss 3.6.0及之前版本一直沿用的接口
第二种Style 根据sql语句和外部传入的总记录数进行分页,这是bboss 3.6.1及之后版本提供的接口
第三种Style 根据sql语句和外部传入的总记录数sql语句进行分页,这是bboss 3.6.1及之后版本提供的接口
第四种Style 使用数据库row_number() over()分析函数结合排序条件实现数据库物理分页

前三种style的支持oracle,mysql,maradb,sqlite,postgres四个主流数据库的高效物理分页,其他数据采用游标机制实现分页(效率相对较低);第4种风格支持oracle,mysql,maradb,sqlite,postgres,derby,ms sql server 2008,db2数据库的高效物理分页(其他类型数据库请采用前面三种风格进行分页)

还有一种不返回总记录数的高效分页查询方法,参考文档: bboss持久层More分页查询API使用介绍

我们根据查询参数的传入方式,分别下面举例介绍四种Style。
1.准备工作-编写一个sql语句配置文件
com/frameworkset/sqlexecutor/purchaseApply.xml
内容如下,用来演示四种Style

<?xml version="1.0" encoding="UTF-8"?>
<properties>
	<property name="queryMaterialList">
	<![CDATA[
		select * from td_app_bom where id=#[id]
		]]>
	</property>
	
	<property name="queryCountMaterialList">
	<![CDATA[
		select count(1) from td_app_bom where id=#[id]
		]]>
	</property>
	
	
	<property name="queryMaterialListbindParam">
	<![CDATA[
		select * from td_app_bom where id=?
		]]>
	</property>
	
	<property name="queryCountMaterialListbindParam">
	<![CDATA[
		select count(1) from td_app_bom where id=?
		]]>
	</property>


	<property name="testsqlinfo"><![CDATA[select * from TD_APP_BOM]]></property>

	<property name="ROW_NUMBERquery"><![CDATA[select * from TD_APP_BOM where 1=1 
			#if($bm && !$bm.equals(""))
				and bm = #[bm]
			#end
			#if($app_name_en && !$app_name_en.equals(""))
				and app_name_en like #[app_name_en]
			#end
			#if($app_name && !$app_name.equals(""))
				and app_name like #[app_name]
			#end
			#if($soft_level && !$soft_level.equals(""))
				and soft_level=#[soft_level]
			#end
			#if($state && !$state.equals(""))
				and state=#[state]
			#end
			#if($rd_type && !$rd_type.equals(""))
				and rd_type=#[rd_type]
			#end ]]></property>

	<property name="ROW_NUMBERquery_orderby"><![CDATA[
		    #if($sortKey && !$sortKey.equals(""))
			  	order by $sortKey 
			  	#if($sortDESC )
				  	desc
				#else
				 	asc
				#end	
			#else
			 	order by bm 
			#end]]></property>
</properties>


说明:
queryMaterialList为分页sql
queryCountMaterialList为查总记录数sql

2.分页查询方法示例代码
public class ApplyService {

	private com.frameworkset.common.poolman.ConfigSQLExecutor executor = new ConfigSQLExecutor("com/frameworkset/sqlexecutor/purchaseApply.xml");
	
	/*******************************以bean方式传递查询条件开始*******************************/
	public ListInfo queryMaterailListInfoFirstStyleBean(int offset, int pagesize ,PurchaseApplyCondition condition) throws Exception {
		
		//执行分页查询,queryMaterialList对应分页查询语句,
		//根据sql语句在分页方法内部执行总记录数查询操作,这种风格使用简单,效率相对较低
		//condition参数保存了查询条件
		return executor.queryListInfoBean(HashMap.class, "queryMaterialList", offset, pagesize,condition);
	}
	
	public ListInfo queryMaterailListInfoSecondStyleBean(int offset, int pagesize ,PurchaseApplyCondition condition) throws Exception {
		//执行总记录查询并存入totalSize变量中,queryCountMaterialList对应一个优化后的总记录查询语句
		//condition参数保存了查询条件
		long totalSize = executor.queryObjectBean(long.class, "queryCountMaterialList", condition);
		//执行总记分页查询,queryMaterialList对应分页查询语句,通过totalsize参数从外部传入总记录数,
		//这样在分页方法内部无需执行总记录数查询操作,以便提升系统性能,这种风格使用简单,效率相对第一种风格较高,但是要额外配置总记录数查询sql
		//condition参数保存了查询条件
		return executor.queryListInfoBean(HashMap.class, "queryMaterialList", offset, pagesize,totalSize ,condition);
	}
	
	
	public ListInfo queryMaterailListInfoThirdStyleBean(int offset, int pagesize ,PurchaseApplyCondition condition) throws Exception {
		//根据sql语句和外部传入的总记录数sql语句进行分页,这种风格使用简单,效率最高,但是要额外配置总记录数查询sql
		ListInfo list = executor.queryListInfoBeanWithDBName(HashMap.class, "bspf","queryMaterialList", 0, 10,"queryCountMaterialList" ,condition);
		return list;
	}
	/*******************************以bean方式传递查询条件结束*******************************/
	
	/*******************************以传统绑定变量方式传递查询条件开始*******************************/
	public ListInfo queryMaterailListInfoFirstStyle(int offset, int pagesize ,String id) throws Exception {
		
		//执行分页查询,queryMaterialList对应分页查询语句,
		//根据sql语句在分页方法内部执行总记录数查询操作,这种风格使用简单,效率相对较低
		//id参数保存了查询条件
		return executor.queryListInfo(HashMap.class, "queryMaterialListbindParam", offset, pagesize,id);
	}
	
	public ListInfo queryMaterailListInfoSecondStyle(int offset, int pagesize ,String id) throws Exception {
		//执行总记录查询并存入totalSize变量中,queryCountMaterialList对应一个优化后的总记录查询语句
		//id参数保存了查询条件
		long totalSize = executor.queryObject(long.class, "queryCountMaterialListbindParam",id);
		//执行总记分页查询,queryMaterialList对应分页查询语句,通过totalsize参数从外部传入总记录数,
		//这样在分页方法内部无需执行总记录数查询操作,以便提升系统性能,这种风格使用简单,效率相对第一种风格较高,但是要额外配置总记录数查询sql
		//id参数保存了查询条件
		return executor.queryListInfoWithTotalsize(HashMap.class, "queryMaterialListbindParam", offset, pagesize,totalSize,id );
	}
	
	
	public ListInfo queryMaterailListInfoThirdStyle(int offset, int pagesize ,String id) throws Exception {
		//根据sql语句和外部传入的总记录数sql语句进行分页,这种风格使用简单,效率最高,但是要额外配置总记录数查询sql,id参数保存了查询条件
		ListInfo list = executor.queryListInfoWithDBName2ndTotalsizesql(HashMap.class, "bspf","queryMaterialListbindParam", 0, 10,"queryCountMaterialListbindParam",id );
		return list;
	}
	/*******************************以传统绑定变量方式传递查询条件结束*******************************/

       /********************************第四种风格测试用例开始******/
public @Test void testoraclerownumoverorderby() throws Exception {
		testsqlinfoorderby("oracle");
	}
	public @Test void testmysqlrownumoverorderby() throws Exception {
		testsqlinfoorderby("mysql");
	}
	public @Test void testderbyrownumoverorderby() throws Exception {
		testsqlinfoorderby("derby");
	}
	public @Test void testsqliterownumoverorderby() throws Exception {
		testsqliteorderby("sqlite");
	}
	
	public @Test void testdb2rownumoverorderby() throws Exception {
		testsqlinfoorderby("db2");
	}
	public @Test void testpostgresrownumoverorderby() throws Exception {
		testsqlinfoorderby("postgres");
	}
	public @Test void testmssqlrownumoverorderby() throws Exception {
		testsqlinfoorderby("mssql");
	}
	public void testsqlinfoorderby(String dbname) throws Exception {
		//读取配置文件中的原生sql(select * from TD_APP_BOM where bm like ?),通过PlainPagineOrderby(原生排序条件封装对象)对象构造函数传入分页排序条件order by bm,分页pageisize=10参数和PlainPagineOrderby之间的是其他绑定变量参数条件
		ListInfo list = executor.queryListInfoWithDBName (HashMap.class, dbname,"testsqlinfo", 0, 10,'%c%',new PlainPagineOrderby("order by bm"));
		Map params = new HashMap();
		params.put("app_name_en", "%C%");
//读取配置文件中的模板sql,通过PlainPagineOrderby(原生排序条件封装对象)对象传入分页排序条件order by bm和其他模板变量参数条件对象
		list = executor.queryListInfoBeanWithDBName (HashMap.class, dbname,"ROW_NUMBERquery", 0, 10,new PlainPagineOrderby("order by bm",params));
		StringBuilder orderby = new StringBuilder();
		orderby.append(" #if($sortKey && !$sortKey.equals(\"\"))")
		.append(" order by $sortKey ")
		.append(" #if($sortDESC )")
		.append("  	desc ")
		.append(" #else")
		.append(" 	asc")
		.append(" #end")
		.append(" #else")
		.append(" order by bm ")
		.append(" #end");
//读取配置文件中的模板sql,通过PagineOrderby(模板动态排序条件封装对象)对象传入分页动态排序条件和其他模板变量参数条件对象
		list = executor.queryListInfoBeanWithDBName (HashMap.class, dbname,"ROW_NUMBERquery", 0, 10,new PagineOrderby(orderby.toString(),params));
		params.put("sortKey", "id");
		params.put("sortDESC", true);
//调整排序字段为id,设置排序顺序为降序,读取配置文件中的模板sql,通过ConfigPagineOrderby(模板动态排序条件封装对象,但是只是指定了一个排序条件的名称,实际是从配置文件读取的)对象传入分页动态排序条件和其他模板变量参数条件对象
		list = executor.queryListInfoBeanWithDBName (HashMap.class, dbname,"ROW_NUMBERquery", 0, 10,new ConfigPagineOrderby("ROW_NUMBERquery_orderby",params));
		//三个SQLExecutor排序分页接口使用用法,除了没有ConfigPagineOrderby分页封装方式外,使用方法与ConfigSQLExecutor使用方法一致
		//SQLExecutor直接操作原生sql(select * from TD_APP_BOM where bm like ?)做分页查询,通过PlainPagineOrderby(原生排序条件封装对象)对象构造函数传入分页排序条件order by bm,分页pageisize=10参数和PlainPagineOrderby之间的是其他绑定变量参数条件,
		list = SQLExecutor.queryListInfoWithDBName (HashMap.class, dbname,"select * from TD_APP_BOM", 0, 10,new PlainPagineOrderby("order by bm"));
		StringBuilder testsqlinfoorderby = new StringBuilder();
		testsqlinfoorderby.append("select * from TD_APP_BOM where 1=1")
				.append("	#if($bm && !$bm.equals(\"\"))")
				.append("	and bm = #[bm]")
				.append("	#end")
				.append("	#if($app_name_en && !$app_name_en.equals(\"\"))")
				.append("		and app_name_en like #[app_name_en]")
				.append("	#end")
				.append("	#if($app_name && !$app_name.equals(\"\"))")
				.append("		and app_name like #[app_name]")
				.append(" #end")
				.append("		#if($soft_level && !$soft_level.equals(\"\"))")
				.append("		and soft_level=#[soft_level]")
				.append("	#end")
				.append("	#if($state && !$state.equals(\"\"))")
				.append("		and state=#[state]")
				.append("		#end")
				.append("			#if($rd_type && !$rd_type.equals(\"\"))")
				.append("	and rd_type=#[rd_type]")
				.append("	#end");
		 
		list = SQLExecutor.queryListInfoBeanWithDBName (HashMap.class, dbname,testsqlinfoorderby.toString(), 0, 10,new PlainPagineOrderby("order by bm",params));
		
		list = SQLExecutor.queryListInfoBeanWithDBName (HashMap.class, dbname,testsqlinfoorderby.toString(), 0, 10,new PagineOrderby(orderby.toString(),params));
	 
		
		return ;
	}
	
	public void testsqliteorderby(String dbname) throws Exception {
		//根据sql语句和外部传入的总记录数sql语句进行分页,这种风格使用简单,效率最高,但是要额外配置总记录数查询sql
		ListInfo list = null;
		Map params = new HashMap();
		params.put("moudleName", "%t%");
		 
		StringBuilder orderby = new StringBuilder();
		orderby.append(" #if($sortKey && !$sortKey.equals(\"\"))")
		.append(" order by $sortKey ")
		.append(" #if($sortDESC )")
		.append("  	desc ")
		.append(" #else")
		.append(" 	asc")
		.append(" #end")
		.append(" #else")
		.append(" order by moudleName ")
		.append(" #end");
	 
		
		
		list = SQLExecutor.queryListInfoWithDBName (HashMap.class, dbname,"select * from BBOSS_GENCODE", 0, 3,new PlainPagineOrderby("order by moudleName"));
		StringBuilder testsqlinfoorderby = new StringBuilder();
		testsqlinfoorderby.append("select * from BBOSS_GENCODE where 1=1")
				.append("	#if($DBNAME && !$DBNAME.equals(\"\"))")
				.append("	and DBNAME = #[DBNAME]")
				.append("	#end")
				.append("	#if($moudleName && !$moudleName.equals(\"\"))")
				.append("		and moudleName like #[moudleName]")
				.append("	#end")
				;
		 
		list = SQLExecutor.queryListInfoBeanWithDBName (HashMap.class, dbname,testsqlinfoorderby.toString(), 0, 3,new PlainPagineOrderby("order by moudleName",params));
		params.put("sortKey", "id");
		params.put("sortDESC", true);
		list = SQLExecutor.queryListInfoBeanWithDBName (HashMap.class, dbname,testsqlinfoorderby.toString(), 0, 3,new PagineOrderby(orderby.toString(),params));
	 
		
		return ;
	}
       /********************************第四种风格测试用例结束******/
}


举例完毕,如有疑问,请留言进一步探讨。
补充说明一下:ListInfo对象包含当页记录集和总记录数以及每页最多纪录数,如果是more分页查询,还包含了more分页标识
相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
2天前
|
SQL Java 数据库连接
Mybatis拦截器实现公共字段填充
通过使用MyBatis拦截器,可以实现对公共字段的自动填充,简化代码,提高开发效率。拦截器通过拦截SQL操作,在插入和更新操作时自动填充公共字段,使得开发者不再需要手动设置这些字段。本文详细介绍了实现步骤,并通过示例代码展示了具体实现方法,希望能为您的开发工作提供实用的指导和帮助。
33 13
|
3月前
|
SQL JSON Java
mybatis使用三:springboot整合mybatis,使用PageHelper 进行分页操作,并整合swagger2。使用正规的开发模式:定义统一的数据返回格式和请求模块
这篇文章介绍了如何在Spring Boot项目中整合MyBatis和PageHelper进行分页操作,并且集成Swagger2来生成API文档,同时定义了统一的数据返回格式和请求模块。
95 1
mybatis使用三:springboot整合mybatis,使用PageHelper 进行分页操作,并整合swagger2。使用正规的开发模式:定义统一的数据返回格式和请求模块
|
3月前
|
SQL Java 数据库连接
mybatis使用四:dao接口参数与mapper 接口中SQL的对应和对应方式的总结,MyBatis的parameterType传入参数类型
这篇文章是关于MyBatis中DAO接口参数与Mapper接口中SQL的对应关系,以及如何使用parameterType传入参数类型的详细总结。
62 10
|
6月前
|
Java 数据库连接 Maven
文本,使用SpringBoot工程创建一个Mybatis-plus项目,Mybatis-plus在编写数据层接口,用extends BaseMapper<User>继承实体类
文本,使用SpringBoot工程创建一个Mybatis-plus项目,Mybatis-plus在编写数据层接口,用extends BaseMapper<User>继承实体类
|
8月前
|
测试技术 数据库
深入探索MyBatis-Plus中Service接口的lambdaUpdate用法及示例
深入探索MyBatis-Plus中Service接口的lambdaUpdate用法及示例
1536 0
|
8月前
|
Java 数据库连接 mybatis
mybatis简单案例源码详细【注释全面】——Dao层接口(UserMapper.java)
mybatis简单案例源码详细【注释全面】——Dao层接口(UserMapper.java)
|
SQL 数据库
springboot+mybatis,mapper调用查询的数据为空,报空指针异常
springboot+mybatis,mapper调用查询的数据为空,报空指针异常
1351 0
|
XML SQL Java
MyBatis-06 MyBatis XML方式之多个接口参数用法
MyBatis-06 MyBatis XML方式之多个接口参数用法
116 0
|
XML SQL Java
mybatis学习(24):分页2 多参数传递(使用注解)
mybatis学习(24):分页2 多参数传递(使用注解)
109 0
mybatis学习(24):分页2 多参数传递(使用注解)
|
SQL 前端开发
【mybatis-plus】分页、逻辑删除
【mybatis-plus】分页、逻辑删除
【mybatis-plus】分页、逻辑删除