- 浏览: 697643 次
- 性别:
- 来自: 长沙
文章分类
- 全部博客 (364)
- quick start (57)
- bboss aop (43)
- bboss mvc (48)
- bboss persistent (96)
- bboss taglib (30)
- bboss event (10)
- bbossgroups (52)
- bboss (32)
- bboss会话共享 (17)
- bboss rpc (7)
- bboss 国际化 (5)
- bboss 序列化 (9)
- bboss cxf webservice (8)
- bboss hessian (3)
- bboss 安全认证SSO (15)
- bboss 工作流 (6)
- 平台 (18)
- bboss quartz (3)
- 杂谈 (5)
- 大数据 (1)
- bboss elastic (24)
- bboss http (1)
- bboss kafka (1)
- Elasticsearch Scroll和Slice Scroll查询API使用案例 (1)
最新评论
-
qianhao123:
...
采用gradle构建和发布bboss方法介绍 -
qianhao123:
[img][/img]
采用gradle构建和发布bboss方法介绍 -
yin_bp:
欢迎大家参与working
高性能elasticsearch ORM开发库使用介绍 -
qq641879434:
万分感谢
bboss 持久层sql xml配置文件编写和加载方法介绍 -
yin_bp:
qq641879434 写道怎么设置配置文件 可以查看执行的S ...
bboss 持久层sql xml配置文件编写和加载方法介绍
为了更好地提高数据库分页查询的效率,bboss持久层在ConfigSQLExecutor和SQLExecutor两个组件中分别提供了一组实用的more分页查询接口。本文着重介绍more分页查询api的使用以及more分页查询和分页标签库结合的一些特殊特性。
1.概述
到目前为止bboss持久层分别提供了以下三种分页查询API:
第一种 普通分页查询操API
这组API自动根据查询sql语句执行总记录数获取和当前页记录集获取两个操作,对应于ConfigSQLExecutor和SQLExecutor中以queryListInfo开头的方法。这组API中返回的ListInfo对象中包含总记录数和当页记录数两个信息,除非没有查询到数据,否则一定有一页数据返回,也就是说当分页起始位置超过总记录数时,就自动返回最后一页数据;当起始位置为0或者小于零时将返回第一页数据。
第二种 带总记录数或者传入总记录数查询sql语句的API
这组API根据传入是总记录数还是总记录数查询sql所做的操作不一样:如果传入的是总记录数,那么这组API将只做当前页记录查询操作,不做总记录数查询操作;如果传入的是总记录数查询sql,那么除了要做当前页记录查询操作外,还要通过总记录数查询sql获取总记录数,也就是说对应的API要执行两次db操作,这种情况相对于普通分页查询API,传入的总记录数查询SQL比普通分页查询API中自动生成的总记录数查询sql效率要高很多。这组api同样对应于ConfigSQLExecutor和SQLExecutor中以queryListInfo开头的方法,只是其中多了totalsize或者totalsizesql参数。这组API中返回的ListInfo对象中包含总记录数和当页记录数两个信息,除非没有查询到数据,否则一定有一页数据返回,也就是说当分页起始位置超过总记录数时,就自动返回最后一页数据;当起始位置为0或者小于零时将返回第一页数据。
第三种 More分页查询API
More分页查询API也就是本文要介绍的功能,这组API只根据传入的当前页记录起始位置和每页最大记录数获取当前页的数据集,不会做总记录数查询,也就是说只做一次db操作,因此more分页查询的效率最好,但是无法提供总记录数据信息,只要在总记录数不是很重要的情况下就可以使用more分页查询方法。如果对应的起始位置没有查询到数据集将不返回任何数据,如果有数据则返回带当页数据的ListInfo对象,并且listInfo对象中没有总记录数信息,也就是调用listInfo.getTotalSize()方法始终返回0。那么More分页接口返回数据时,我们怎么判断已经到了最后一页或者是没有数据呢,首先如果获取数据起始位置为0,当调用listInfo.getResultSize()方法返回0时表示没有数据;如果获取数据起始位置大于0,当调用listInfo.getResultSize()方法返回值为0或者返回值小于每页需获取记录数时表示已经到达记录的最后一页。
普通分页查询操API和带总记录数或者传入总记录数查询sql语句API的使用方法请参考博文《bboss持久层分页接口使用示例》,本文着重介绍more分页查询api的使用以及more分页查询和分页标签库结合的一些特殊特性。
2.More分页查询api
下面列出more分页的对应ConfigSQLExecutor组件中所有api:
Class<?> beanType参数对应要返回的记录对应的对象类型,sqlname参数对应ConfigSQLExecutor加载的xml sql配置文件中的sql配置名称,Object... fields对应原生sql的可变长参数数组;,Object bean参数得属性对应承载了sqlname参数对应的sql语句需要的所有参数值和控制变量值,offset对应分页数据起始位置,pagesize参数指定了当页需要获取的记录数。NullRowHandler 和 RowHandler 类型参数对应了用户自定义处理记录的行处理器。
下面列出more分页的对应SQLExecutor组件中所有api:
Class<?> beanType参数对应要返回的记录对应的对象类型,sql参数对应SQLExecutor要执行的sql语句,Object... fields对应原生sql的可变长参数数组;,Object bean参数得属性对应承载了sql参数对应的sql语句需要的所有参数值和控制变量值,offset对应分页数据起始位置,pagesize参数指定了当页需要获取的记录数。NullRowHandler和 RowHandler 类型参数对应了用户自定义处理记录的行处理器。
3.more查询分页api使用示例
ConfigSQLExecutor:
SQLExecutor:
4.more分页查询与分页标签库结合使用
more分页查询的使用方法和前面的两种分页查询的方法使用方式是一样的,唯一的区别是返回的ListInfo对象实例datas被调用listInfo的setMore(true)方法标识为more查询返回的listInfo对象了。这个more状态标识将影响分页标签的Index分页导航标签展示行为,同时分页标签中获取到总记录数值为0,但是这个标识不会影响我们分页标签的编程使用方法,通过以下两个图对比就可以看出二者Index导航效果的区别:
more分页查询的效果
非more分页查询的效果
上面的导航都是通过以下的index标签用法输出的:
<pg:index tagnumber="10" sizescope="5,10,20,50,100"/>
为了配合在pager标签上提供的statement属性指定的sql直接从数据库查询分页数据时也能使用more分页查询,我们在pager标签上提供了moreQuery属性,moreQuery为true时将使用more分页查询获取数据,false不使用,默认为false。moreQuery属性的使用方法如下:
1.概述
到目前为止bboss持久层分别提供了以下三种分页查询API:
第一种 普通分页查询操API
这组API自动根据查询sql语句执行总记录数获取和当前页记录集获取两个操作,对应于ConfigSQLExecutor和SQLExecutor中以queryListInfo开头的方法。这组API中返回的ListInfo对象中包含总记录数和当页记录数两个信息,除非没有查询到数据,否则一定有一页数据返回,也就是说当分页起始位置超过总记录数时,就自动返回最后一页数据;当起始位置为0或者小于零时将返回第一页数据。
第二种 带总记录数或者传入总记录数查询sql语句的API
这组API根据传入是总记录数还是总记录数查询sql所做的操作不一样:如果传入的是总记录数,那么这组API将只做当前页记录查询操作,不做总记录数查询操作;如果传入的是总记录数查询sql,那么除了要做当前页记录查询操作外,还要通过总记录数查询sql获取总记录数,也就是说对应的API要执行两次db操作,这种情况相对于普通分页查询API,传入的总记录数查询SQL比普通分页查询API中自动生成的总记录数查询sql效率要高很多。这组api同样对应于ConfigSQLExecutor和SQLExecutor中以queryListInfo开头的方法,只是其中多了totalsize或者totalsizesql参数。这组API中返回的ListInfo对象中包含总记录数和当页记录数两个信息,除非没有查询到数据,否则一定有一页数据返回,也就是说当分页起始位置超过总记录数时,就自动返回最后一页数据;当起始位置为0或者小于零时将返回第一页数据。
第三种 More分页查询API
More分页查询API也就是本文要介绍的功能,这组API只根据传入的当前页记录起始位置和每页最大记录数获取当前页的数据集,不会做总记录数查询,也就是说只做一次db操作,因此more分页查询的效率最好,但是无法提供总记录数据信息,只要在总记录数不是很重要的情况下就可以使用more分页查询方法。如果对应的起始位置没有查询到数据集将不返回任何数据,如果有数据则返回带当页数据的ListInfo对象,并且listInfo对象中没有总记录数信息,也就是调用listInfo.getTotalSize()方法始终返回0。那么More分页接口返回数据时,我们怎么判断已经到了最后一页或者是没有数据呢,首先如果获取数据起始位置为0,当调用listInfo.getResultSize()方法返回0时表示没有数据;如果获取数据起始位置大于0,当调用listInfo.getResultSize()方法返回值为0或者返回值小于每页需获取记录数时表示已经到达记录的最后一页。
普通分页查询操API和带总记录数或者传入总记录数查询sql语句API的使用方法请参考博文《bboss持久层分页接口使用示例》,本文着重介绍more分页查询api的使用以及more分页查询和分页标签库结合的一些特殊特性。
2.More分页查询api
下面列出more分页的对应ConfigSQLExecutor组件中所有api:
public ListInfo moreListInfoWithDBNameByRowHandler(RowHandler rowhandler,Class<?> beanType,String dbname, String sqlname, long offset,int pagesize,Object... fields) throws SQLException public ListInfo moreListInfoWithDBNameByNullRowHandler(NullRowHandler rowhandler,String dbname, String sqlname, long offset,int pagesize,Object... fields) throws SQLException public ListInfo moreListInfoWithDBName(Class<?> beanType,String dbname, String sqlname, long offset,int pagesize,Object... fields) throws SQLException public ListInfo moreListInfoByRowHandler(RowHandler rowhandler,Class<?> beanType, String sqlname, long offset,int pagesize,Object... fields) throws SQLException public ListInfo moreListInfoByNullRowHandler(NullRowHandler rowhandler, String sqlname, long offset,int pagesize,Object... fields) throws SQLException public ListInfo moreListInfoBeanWithDBNameByRowHandler(RowHandler rowhandler,Class<?> beanType,String dbname, String sqlname, long offset,int pagesize,Object bean) throws SQLException public ListInfo moreListInfoBeanWithDBNameByNullRowHandler(NullRowHandler rowhandler,String dbname, String sqlname, long offset,int pagesize,Object bean) throws SQLException public ListInfo moreListInfoBeanWithDBName(Class<?> beanType,String dbname, String sqlname, long offset,int pagesize,Object bean) throws SQLException public ListInfo moreListInfoBeanByRowHandler(RowHandler rowhandler,Class<?> beanType, String sqlname, long offset,int pagesize,Object bean) throws SQLException public ListInfo moreListInfoBeanByNullRowHandler(NullRowHandler rowhandler, String sqlname, long offset,int pagesize,Object bean) throws SQLException public ListInfo moreListInfoBean(Class<?> beanType, String sqlname, long offset,int pagesize,Object bean) throws SQLException public ListInfo moreListInfo(Class<?> beanType, String sqlname, long offset,int pagesize,Object... fields) throws SQLException
Class<?> beanType参数对应要返回的记录对应的对象类型,sqlname参数对应ConfigSQLExecutor加载的xml sql配置文件中的sql配置名称,Object... fields对应原生sql的可变长参数数组;,Object bean参数得属性对应承载了sqlname参数对应的sql语句需要的所有参数值和控制变量值,offset对应分页数据起始位置,pagesize参数指定了当页需要获取的记录数。NullRowHandler 和 RowHandler 类型参数对应了用户自定义处理记录的行处理器。
下面列出more分页的对应SQLExecutor组件中所有api:
public ListInfo moreListInfoWithDBNameByRowHandler(RowHandler rowhandler,Class<?> beanType,String dbname, String sql, long offset,int pagesize,Object... fields) throws SQLException public ListInfo moreListInfoWithDBNameByNullRowHandler(NullRowHandler rowhandler,String dbname, String sql, long offset,int pagesize,Object... fields) throws SQLException public ListInfo moreListInfoWithDBName(Class<?> beanType,String dbname, String sql, long offset,int pagesize,Object... fields) throws SQLException public ListInfo moreListInfoByRowHandler(RowHandler rowhandler,Class<?> beanType, String sql, long offset,int pagesize,Object... fields) throws SQLException public ListInfo moreListInfoByNullRowHandler(NullRowHandler rowhandler, String sql, long offset,int pagesize,Object... fields) throws SQLException public ListInfo moreListInfoBeanWithDBNameByRowHandler(RowHandler rowhandler,Class<?> beanType,String dbname, String sql, long offset,int pagesize,Object bean) throws SQLException public ListInfo moreListInfoBeanWithDBNameByNullRowHandler(NullRowHandler rowhandler,String dbname, String sql, long offset,int pagesize,Object bean) throws SQLException public ListInfo moreListInfoBeanWithDBName(Class<?> beanType,String dbname, String sql, long offset,int pagesize,Object bean) throws SQLException public ListInfo moreListInfoBeanByRowHandler(RowHandler rowhandler,Class<?> beanType, String sql, long offset,int pagesize,Object bean) throws SQLException public ListInfo moreListInfoBeanByNullRowHandler(NullRowHandler rowhandler, String sql, long offset,int pagesize,Object bean) throws SQLException public ListInfo moreListInfoBean(Class<?> beanType, String sql, long offset,int pagesize,Object bean) throws SQLException public ListInfo moreListInfo(Class<?> beanType, String sql, long offset,int pagesize,Object... fields) throws SQLException
Class<?> beanType参数对应要返回的记录对应的对象类型,sql参数对应SQLExecutor要执行的sql语句,Object... fields对应原生sql的可变长参数数组;,Object bean参数得属性对应承载了sql参数对应的sql语句需要的所有参数值和控制变量值,offset对应分页数据起始位置,pagesize参数指定了当页需要获取的记录数。NullRowHandler和 RowHandler 类型参数对应了用户自定义处理记录的行处理器。
3.more查询分页api使用示例
ConfigSQLExecutor:
ListInfo datas=executor.moreListInfoBean(AppBom.class,"queryListAppBom", offset, pagesize, appcondition);
SQLExecutor:
ListInfo datas=SQLExecutor.moreListInfoBean(AppBom.class,"select * from td_app_bom where id=#[id] and name like #[name]", offset, pagesize, appcondition);
4.more分页查询与分页标签库结合使用
more分页查询的使用方法和前面的两种分页查询的方法使用方式是一样的,唯一的区别是返回的ListInfo对象实例datas被调用listInfo的setMore(true)方法标识为more查询返回的listInfo对象了。这个more状态标识将影响分页标签的Index分页导航标签展示行为,同时分页标签中获取到总记录数值为0,但是这个标识不会影响我们分页标签的编程使用方法,通过以下两个图对比就可以看出二者Index导航效果的区别:
more分页查询的效果
非more分页查询的效果
上面的导航都是通过以下的index标签用法输出的:
<pg:index tagnumber="10" sizescope="5,10,20,50,100"/>
为了配合在pager标签上提供的statement属性指定的sql直接从数据库查询分页数据时也能使用more分页查询,我们在pager标签上提供了moreQuery属性,moreQuery为true时将使用more分页查询获取数据,false不使用,默认为false。moreQuery属性的使用方法如下:
<pg:pager scope="request" statement="select * from td_app_bom" dbname="bspf" moreQuery="true" desc="false" isList="false" > <pg:list> <pg:cell colName="struct_mode" maxlength="8" replace="..."/> </pg:list> <pg:index tagnumber="10" sizescope="5,10,20,50,100"/> </pg:pager>
发表评论
-
bboss 持久层数据源引用外部属性配置介绍
2018-12-29 21:47 1099bboss 持久层数据源外部属性配置引用介绍 bboss持久 ... -
bboss持久层开启和关闭自带主键机制
2017-08-17 11:56 755bboss持久层开启和关闭自带主键机制 请访问文档: bbos ... -
bboss高性能db批处理功能使用方法介绍
2017-05-14 21:28 2147bboss持久层在v5.0.3.5中新增简单的高效的db批处理 ... -
bboss持久层公共sql片段定义和引用方法说明
2017-03-03 13:05 1130bboss持久层公共sql片段定义和引用方法说明 在配置sq ... -
最新版本mysql jdbc驱动包获取表定义信息空指针异常处理方法
2016-12-15 10:24 1366在使用最新的mysql-connector-java 6.0. ... -
bboss标签库cell标签格式化数字实例
2016-11-24 10:38 925bboss标签库cell标签格式化数字实例 带double类 ... -
bboss标签库cell标签展示嵌套对象属性方法实例
2016-11-16 21:47 964bboss标签库cell标签展示 ... -
持久层快速入门系列一
2016-08-19 13:00 1266持久层快速入门 先在应用中导入bboss 持久层(bboss ... -
bboss与spring中配置和引用bboss数据源和bboss dao组件方法说明
2016-08-10 16:04 921首先在项目中导入bboss 持久层包: maven坐标 & ... -
bboss 持久层sql xml配置文件编写和加载方法介绍
2016-04-05 13:14 1699bboss 持久层sql xml配置文件编写和加载方法介绍 通 ... -
bboss标签库list/map标签循环变量var属性使用说明
2015-12-24 09:17 1381bboss标签库list/map标签循环变量var属性使用说明 ... -
bboss持久层设置数据库查询fetchsize参数方法
2015-11-06 11:54 1018bboss持久层设置数据库查询fetchsize参数方法 j ... -
bboss持久层快速入门教程
2015-09-19 13:49 1594bboss持久层快速入门教程,快速搭建bboss持久层的开 ... -
bboss持久层数据库适配器编写和注册方法
2015-02-06 15:21 978bboss持久层数据库适配器编写和注册方法 bboss持久层默 ... -
bboss模糊查询、动态sql、批处理资料荟萃
2015-01-30 12:03 2375bboss模糊查询、动态sql、批处理资料荟萃 bboss持 ... -
bboss逻辑标签实现if-else以及if-else if-else条件判断功能介绍
2014-11-25 23:43 1795采用bboss逻辑标签可以非常容易地实现if-else以及if ... -
bboss持久层查询元数据缓存机制开启方法
2014-11-18 12:03 1024bboss持久层为了提升数据库查询操作性能,提供了对查 ... -
bboss标签实现列表中的动态列数据展示方法
2014-10-26 12:46 1319借助bboss标签库提供的list标签,我们可以非常方便地实现 ... -
bboss逻辑标签判断对象类型是否为给定的Class类型方法
2014-10-12 11:35 888在java代码中可以非常方 ... -
bboss数据库标签系列一 分页列表详细信息标签预编译sql查询数据
2014-10-09 12:54 1129本系列文章详细介绍bboss标签库的数据库标签具体使用方法,涉 ...
相关推荐
bboss-plugins project.包含kafka、log4j、spring、dubbo、activemq、word转pdf、pdf转swf项目,持久层hibernate/hibernate4插件
该项目为bboss插件集的Java设计源码,总计277个文件,涵盖163个Java源文件、22个XML配置文件、14个Gradle构建脚本、13个Git忽略规则、13个属性文件以及少量的JavaScript、HTML、CSS和Shell脚本,主要用于文档转换和...
本文将详细介绍如何在BBoss的IOC配置文件中引用外部属性文件,以便更好地管理和动态配置应用。 首先,BBoss的IOC配置文件通常是一个XML文件,比如`bboss-ioc.xml`,在这个文件中我们可以声明并配置各种bean。当需要...
- 模型层详解:介绍如何定义模型类,以及如何与数据访问层交互,执行CRUD操作。 - 视图渲染:如何配置和使用不同的模板引擎,以及如何在视图中展示模型数据。 - AOP应用:示例展示如何定义切面,以及如何应用事务...
最后,bboss会话共享的逻辑架构要求遵循Servlet 2/3规范API,通过HttpSession接口获取会话数据。通过这样的实现,bboss会话共享不仅在技术层面解决了会话管理的难题,还确保了与业界主流技术的兼容性,提高了系统的...
2. **bboss elasticsearch开发入门教程.wmv**: 通过实例演示,讲解如何使用BBoss进行索引操作、数据插入、查询和更新,帮助初学者快速上手。 **六、资料阅读** "说明.txt" 文件可能包含了关于这些教程的详细步骤和...
2. **数据库操作**:BBoss提供了便捷的数据访问层(DAO),支持SQL动态生成、事务管理以及多种数据库的兼容性,使得数据库操作变得简单且高效。 3. **服务治理**:框架内置了服务注册与发现机制,可以实现微服务...
然后可以通过bboss提供的API进行索引创建、数据插入、查询、更新、删除等操作。 4. **DSL操作** Domain Specific Language是bboss支持的一种面向领域的特定语言,允许开发者使用JSON格式定义查询和更新语句。DSL...
BBoss安全认证过滤器是Java Web开发中一种用于实现用户身份验证和权限控制的重要组件。在Web应用程序中,过滤器(Filter)是Servlet规范的一部分,它允许开发者在请求到达目标Servlet或JSP之前进行预处理,以及在...
本实例是一个基于bboss es spring boot starter的demo maven工程,可供spring boot项目集成bboss elasticsearch rest client参考 展示了通过spring boot管理单集群功能和管理多集群功能 单集群测试用例:...
Elasticsearch rest client bboss介绍-Elastic2018中国开发者大会演讲稿
BBoss-DB-Elasticsearch-Tool提供了一套API,使得开发者能够便捷地将Java对象存入Elasticsearch索引,或者从索引中检索数据,同时支持复杂的查询和聚合操作。 除了基本的CRUD(创建、读取、更新、删除)操作,BBoss...
BBoss Persistent是一个轻量级的持久层框架,它提供了方便的方式来处理这些大字段。本文将深入探讨在BBoss Persistent 1.0.2中如何高效地管理CLOB和BLOB数据。 首先,CLOB用于存储大量的文本数据,如长篇文章或XML...
3. `bboss-util-5.5.0.jar`和`bboss-persistent-5.5.0.jar`:这是BBoss框架的核心组件,提供了许多实用工具类和持久化操作支持,如数据库连接、事务管理等,为Elasticsearch的数据导入提供底层支持。 4. `...
springboot集成ElasticsearchBboss调用Elasticsearch的案例分享
**bboss-datatran** 是一个由 **bboss** 社区开源的高效数据处理工具,专注于数据采集、数据清洗转换以及数据入库等任务。...通过深入学习和使用bboss-datatran,用户可以提升数据处理效率,更好地挖掘数据的价值。
本培训文档将介绍集群session管理的发展历史、bbosssession的架构及特点、性能指标、与应用的集成方式、部署模式以及场景演示等,旨在帮助技术人员理解并掌握bbosssession的使用方法和优势。 一、集群session管理...
1. **BBoss框架入门**:介绍如何安装配置BBoss,以及创建第一个项目的基本步骤。 2. **BBoss核心组件讲解**:详细解析BBoss的各个模块,如DAO、Service、权限控制等的使用方法。 3. **EasyUI组件使用**:讲解如何在...