基本原理:使用xsqlbuilder框架完成动态sql的构建。

基本流程:使用WebUtils.getParametersStartingWith(ServletActionContext.getRequest(), "s_")根据request找到提交请求的jsp页面并且找到请求参数,从参数中获得所有以s_开始的参数的键值对返还的是一个map对象。然后info.getFilters().putAll(WebUtils.getParametersStartingWith(ServletActionContext.getRequest(), "s_"));
    info.getFilters().putAll(
      WebUtils.getParametersStartingWith(ServletActionContext.getRequest(), tableId + "_f_"));在pageinfo中获得filter对象,此filter对象是从limit对象中获得的,但是在limit中次filter对象始终为空。在构建完成pageinfo对象后次filter属性仍然为空。必须在newPageInfo()函数中设置其filter属性的值为list.jsp页面中对于的查询条件匹配的表单元素。并且匹配是按照name属性进行匹配的,所有想添加到filter中希望通过在dao层动态构建sql的表单元素的name必须用“s_”开头,才能添加到filter中。最终返还的是pageInfoImpl对象。

由pageinfo对象再在dao层中构建动态sql。在findBy方法中XsqlBuilder builder = new XsqlBuilder(SafeSqlProcesserFactory.getOracle());构造xsqlbuilder对象。

XsqlBuilder.XsqlFilterResult queryXsqlResult = builder.generateHql(query, filters);产生XsqlFilterResult对象然后执行如下方法:

private Page findBy(final PageInfo pageInfo, final XsqlBuilder.XsqlFilterResult queryXsqlResult, final XsqlBuilder.XsqlFilterResult countQueryXsqlResult)
  {
    return (Page)getHibernateTemplate().execute(new HibernateCallback()
    {
      public Object doInHibernate(Session session) throws HibernateException, SQLException
      {
        Query query = AbstractHibernateDao.setQueryParameters(session.createQuery(queryXsqlResult.getXsql()), queryXsqlResult.getAcceptedFilters());

Query countQuery = AbstractHibernateDao.setQueryParameters(session.createQuery(HqlRemoveUtils.removeOrders(countQueryXsqlResult.getXsql())), countQueryXsqlResult.getAcceptedFilters());

return new Hibernate3Page(query, countQuery, pageInfo.getPageNumber(), pageInfo.getPageSize());
      }
    });
  }

最终返还的是hibernate3page对象,实际是是page对象的子类。在此page对象中必须要初始化其中的element元素,其中保存了所有通过sql查询出来的结构集数据

public Hibernate3Page(Query selectQuery, Query countQuery, int pageNumber, int pageSize)
  {
    try
    {
      if (countQuery.uniqueResult() != null)
        init(pageNumber, pageSize, Integer.parseInt(countQuery.uniqueResult().toString()));
      else
        init(pageNumber, pageSize, 0);
      if (getTotalNumberOfElements() == 0)
        this.elements = new ArrayList(0);
      else
        this.elements =
          selectQuery.setFirstResult((this.pageNumber - 1) * this.pageSize)
          .setMaxResults(this.pageSize).list();
    }
    catch (HibernateException e) {
      throw new RuntimeException(e);
    }
  }

在初始化element元素时使用了setFirstResult和setMaxResults设置分页显示对query对象执行list返还包含所有结果集的arraylist对象。

后续调用savepage方法

public void savePage(String tableId, Page page)
  {
    Assert.notNull(tableId);
    getRequest().setAttribute(tableId + "List", page.getThisPageElements());
    getRequest().setAttribute(tableId + "_totalRows", Integer.valueOf(page.getTotalNumberOfElements()));
  }

在request中写入element元素。在search.jsp页面中通过<ec:table></ec:table>获得request中的list对象遍历显示在页面上。

补充:limit对象的构建

limit对象时由ecside复制初始化的

LimitFactory limitFactory = new TableLimitFactory(context, tableId);
    TableLimit limit = new TableLimit(limitFactory);

开发时只需要调用Limit limit=RequestUtils.getLimit(getRequest(),"LgpProduct");就可以初始化完成limit对象。

在ecside中有LimitFactory对象构造limit对象在TableLimitFactory中包含了limit中的所有属性

通过init方法载入ecside.properties文件,通过this.registry = new LimitRegistry(context, tableId, prefixWithTableId, state, stateAttr);初始化sortMap对象。将其所有属性赋值给limit对象。然后再有limit来初始化pageinfo对象。借用pageinfo中的filter完成动态sql的构建返回page对象。

动态sql构建的过程的更多相关文章

  1. 本地动态SQL

    (转自:http://blog.itpub.net/26622598/viewspace-718134) 一.什么是动态SQL 大多数PL/SQL都做着一件特殊的结果可预知的工作.例如,一个存储过程可 ...

  2. Mybatis系列全解(八):Mybatis的9大动态SQL标签你知道几个?提前致女神!

    封面:洛小汐 作者:潘潘 2021年,仰望天空,脚踏实地. 这算是春节后首篇 Mybatis 文了~ 跨了个年感觉写了有半个世纪 ... 借着女神节 ヾ(◍°∇°◍)ノ゙ 提前祝男神女神们越靓越富越嗨 ...

  3. mybatis源码学习(四):动态SQL的解析

    之前的一片文章中我们已经了解了MappedStatement中有一个SqlSource字段,而SqlSource又有一个getBoundSql方法来获得BoundSql对象.而BoundSql中的sq ...

  4. PL/SQL --> 动态SQL调用包中函数或过程

    动态SQL主要是用于针对不同的条件或查询任务来生成不同的SQL语句.最常用的方法是直接使用EXECUTE IMMEDIATE来执行动态SQL语句字符串或字符串变量.但是对于系统自定义的包或用户自定的包 ...

  5. plsql programming 16 动态SQL和动态PLSQL

    动态SQL 是指在执行时才构建 SQL 语句, 相对于静态 sql 的编译时就已经构建. 动态PLSQL 是指整个PL/SQL代码块都是动态构建, 然后再编译执行的. 作用: 1. 可以支持 DDL ...

  6. mybatis原理分析学习记录,mybatis动态sql学习记录

    以下个人学习笔记,仅供参考,欢迎指正. MyBatis 是支持定制化 SQL.存储过程以及高级映射的持久层框架,其主要就完成2件事情: 封装JDBC操作 利用反射打通Java类与SQL语句之间的相互转 ...

  7. MyBatis 源码分析 - SQL 的执行过程

    * 本文速览 本篇文章较为详细的介绍了 MyBatis 执行 SQL 的过程.该过程本身比较复杂,牵涉到的技术点比较多.包括但不限于 Mapper 接口代理类的生成.接口方法的解析.SQL 语句的解析 ...

  8. java版云笔记(九)之动态sql

    SQL 首先,所谓SQL的动态和静态,是指SQL语句在何时被编译和执行,二者都是用在SQL嵌入式编程中的,这里所说的嵌入式是指将SQL语句嵌入在高级语言中,而不是针对于单片机的那种嵌入式编程. 静态S ...

  9. EF性能分析(一):动态SQL性能差.从OrderBy开始分析

    1. 问题背景 在我的力推下,部门业务开发转向ABP,其中ORM采用的是EntityFrameworkCore. 然而,在数据查询方面,出现了重大的性能问题... 请看代码: //在一个百万数据量的表 ...

随机推荐

  1. .net程序员转战android第一篇---环境部署

    对于.net开发人员去写java,可谓说是见山是山, 因为太多的相同; 最近段时间因工作因素,将项目中部分功能需要移植到android平台上,经过半个月的煎熬,终于搞完了. 文章中将直观记录我做项目中 ...

  2. 蜗牛爱课 -- iOS 设置UIButton的字体的大小、显示位置、大小

    /设置按钮上的自体的大小 //[btn setFont: [UIFont systemFontSize: 14.0]];    //这种可以用来设置字体的大小,但是可能会在将来的SDK版本中去除改方法 ...

  3. juce中的BailOutChecker

    界面库中值得注意的一点就是对象响应事件的时候自身被删除了,那么后续的访问自然就会出问题,所以需要在响应事件之后先添加引用,相关处理之后再查看自身是否已经被删除,如果已经被删除那么就直接退出.juce中 ...

  4. CxImage整理(叠加字符/图像合并)

    //CxImage叠加字符 void CCxImageTestDlg::OnBnClickedButton1() { CxImage imgJPG; // 定义一个CxImage对象 imgJPG.L ...

  5. JavaWeb核心编程之(四.1)JSP

    JSP简介: JSP是简化Servlet编写的一种技术, 它将Java代码和HTML语句混合在一个文件中编写, 只对网页中药动态产生的内容采用Java代码来编写, 而对固定不变的静态内容采用普通的静态 ...

  6. JavaScript 对象扩展代码

    JavaScript 扩展代码 更具需要写的几个扩展. 扩展核心自执行函数 Object.extend /** * 对象扩展体 参数是 {属性|方法:属性值|方法体} * 只执行实现 * * 实例对基 ...

  7. XML字符串转化json

    public static String XMLTOJSON(String XMLContent,String tag) {  XMLSerializer xmlSerializer = new XM ...

  8. HTML5新元素

    <figure> 标签规定独立的流内容(图像.图表.照片.代码等等). <figure> 元素的内容应该与主内容相关,同时元素的位置相对于主内容是独立的.如果被删除,则不应对文 ...

  9. shopncv4 短信接口 提供商 中国短信网

    前提是在后台开启手机注册功能:具体是在设置->账号同步->手机短信 里开启.   修改 siteroot\core\framework\libraries\sms.php   修改 sit ...

  10. chroot

    用途:更改命令的根目录. 语法:chroot Directory Command 描述: 注意:如果新根目录中的特殊文件具有与实际根目录不同的主要和次要设备号,则可能会覆盖文件系统. 只有具有 roo ...