`
hao861002
  • 浏览: 87905 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

hibernate 多条件组合查询 之 sql 拼接

阅读更多

public static void main(String[] args) {

      
       Session session = null;
       Transaction tx = null;
       List list = null;
       Criteria criteria = null;
 
       try {
 
           session = HibernateSessionFactory.getSession();
           tx = session.beginTransaction();
 
           DetachedCriteria detachedCriteria = DetachedCriteria
                  .forClass(InfoTab.class);
          
          
           String sql=" 1=1 ";
          
           Integer pareaId = 0; // 父地区;
           Integer careaId = 0; // 子地区;
           Integer categoryId = 0; // 类别;
           String infoPrivider = "中介"; // 来源;
           String houseType= "地下室"; // 房屋类型;
           Integer hxBedRoom=0; // 室;
           Integer hxLivingRoom=0; // 厅;
          
           String hzHouseStatus="有房出租"; // 合租类型;
           String hzRequestSex=""; // 性别要求;
           String fixUp="尚未"; // 装修程度;
           Integer lcHeightMolecuse=0; // 楼层;
           String orientation="东南"; // 朝向要求;
           Integer buildArea=2000; // 建筑面积;
           Integer useArea=80; // 使用面积;
           Integer rentalDigit=2000; // 租金/价格;
           String title= "出租"; // 标题;
          
           if(pareaId!=0)
           {
              sql+="pareaId=" + pareaId;
           }
           if(careaId!=0)
           {
              sql+=" and careaId=" + careaId;
           }
           if(categoryId!=0)
           {
              sql+=" and categoryId=" + categoryId;
           }
           if(!infoPrivider.equals(""))
           {
              sql+=" and infoPrivider='" + infoPrivider + "'";
           }
           if(!houseType.equals(""))
           {
              sql+=" and houseType='" + houseType +"'";
           }
           if(hxBedRoom!=0)
           {
              sql+=" and hxBedRoom=" + hxBedRoom;
           }
           if(hxLivingRoom!=0)
           {
              sql+=" and hxLivingRoom=" + hxLivingRoom;
           }
           if(!hzHouseStatus.equals(""))
           {
              sql+=" and hzHouseStatus='" + hzHouseStatus + "'";
           }
           if(!hzRequestSex.equals(""))
           {
              sql+=" and hzRequestSex='" + hzRequestSex +"'";
           }
           if(!fixUp.equals(""))
           {
              sql+=" and fixUp='" + fixUp + "'";
           }
           if(lcHeightMolecuse!=0)
           {
              sql+=" and lcHeightMolecuse=" + lcHeightMolecuse;
           }
           if(!orientation.equals(""))
           {
              sql+=" and orientation='" + orientation + "'";
           }
           if(buildArea!=0)
           {
               sql+=" and buildArea=" + buildArea;
           }
           if(useArea!=0)
           {
              sql+=" and useArea=" + useArea;
           }
           if(rentalDigit!=0)
           {
              sql+=" and rentalDigit=" + rentalDigit;
           }
           if(!title.equals(""))
           {
              sql+=" and title like '%" + title + "%'";
           }
           sql+=" order by id desc";
          
           System.out.println(sql);
 
           detachedCriteria.add(Restrictions.sqlRestriction(sql));
 
           criteria = detachedCriteria.getExecutableCriteria(session);
 
           list = criteria.list();
          
           for(int i=0;i<list.size();i++)
           {
              InfoTab infoTab = (InfoTab)list.get(i);
              System.out.println(infoTab.getTitle() +" "+ infoTab.getCategoryId() +" "+ infoTab.getPareaName() +" "+ infoTab.getCareaName() +" " + infoTab.getHouseType() +" " + infoTab.getInfoPrivider());
           }
 
           tx.commit();
 
       } catch (HibernateException he) {
           he.printStackTrace();
       }
    }
分享到:
评论

相关推荐

    hibernate hql where语句拼接工具类

    总的来说,“hibernate hql where语句拼接工具类”是为了简化和规范化在Hibernate中构建带有动态条件的HQL查询的过程,提高代码的可读性和可维护性。通过这样的工具类,开发者可以更方便地根据业务需求构建复杂的...

    SQL语句拼接

    在实际开发过程中,为了实现动态SQL查询的功能,开发者常常需要根据不同的条件来构造SQL语句。这种根据条件动态生成SQL的过程就被称为SQL语句拼接。这种方式尤其适用于那些查询条件不确定或可变的场景,例如用户可以...

    Hibernate中Sql语句

    条件判断并拼接SQL语句 ``` - **执行查询**:通过`Session`的`createSQLQuery`方法创建`SQLQuery`对象,并设置结果转换方式,最后执行查询并返回结果。 ```java SQLQuery query1 = session.createSQLQuery(sql);...

    Java 使用注解拼接SQL语句

    "Java使用注解拼接SQL语句"是一个常见的实践,它使得动态构建SQL查询变得更为简洁和可维护。这种技术通常与ORM(对象关系映射)框架如MyBatis或Hibernate结合使用,但也可以通过自定义处理逻辑实现。 1. **自定义...

    前台拼接SQL语句

    4. 使用ORM(对象关系映射)框架,如Hibernate或Entity Framework,它们会自动处理SQL拼接和安全问题。 5. 避免在前端暴露敏感信息,如数据库结构、表名或字段名。 综上所述,"前台拼接SQL语句"是一个重要的安全...

    三种查询方式跟踪Hibernate源码

    在执行`createCriteria()`或`createCriteriaJoin()`等方法时,Hibernate会构建一个表示查询条件的抽象语法树(AST)。`org.hibernate.criterion`包中的类如`DetachedCriteria`、`Expression`等用于构建这些条件。...

    Hibernate查询解决方案

    Hibernate 的核心功能之一是提供了一套强大的查询接口和方法,包括基于对象的查询、SQL 查询和 HQL (Hibernate Query Language) 查询等。本文将详细介绍 Hibernate 提供的几种查询方式及其应用场景。 #### 二、重要...

    hibernate结构化查询

    在Java持久化框架Hibernate中,结构化查询是其强大功能之一,它允许开发者以面向对象的方式构建复杂的SQL查询。Criteria API就是实现这一功能的核心组件,它提供了一种更安全、可读性更强的方式来代替传统的HQL...

    sql注入和防SQL注入

    1. **参数化查询**:使用预编译的SQL语句,将用户输入作为参数传递,而不是直接拼接在SQL字符串中。例如,使用ORM框架(如Hibernate、Entity Framework)或数据库提供的API(如PDO、PreparedStatement)。 2. **输入...

    sql字符拼接类

    简洁明了,类似于hibernate的criteria,不依赖其他任何框架和包,还具备防注入能力。我从githug找到一个原始版本,功能不完善且太复杂。我fork了自己的一个版本,有高手可以跟进下...

    day36 04-Hibernate检索方式:多表连接查询

    标题中的“day36 04-Hibernate检索方式:多表连接查询”表明这是一个关于Hibernate框架的教程,重点讲解如何在Hibernate中进行多表连接查询。在这个主题中,我们将深入探讨Hibernate的ORM(对象关系映射)机制以及...

    Hibernate使用中防止SQL注入的几种方案

    这样的方式,Hibernate会自动处理参数,避免了直接将用户输入拼接到SQL字符串中。 2. **对参数位置进行绑定**: 类似于上一种方法,但不指定参数名,而是根据参数位置设置值。例如: ```java Query query = ...

    sql的封装,不需要使用StringBuffer进行字符串拼接

    在SQL编程中,通常我们需要动态构建SQL语句来适应不同的查询条件。早期的开发实践中,开发者经常使用`StringBuffer`或`StringBuilder`来拼接这些条件,但这并不是一个高效且安全的方法。本话题将深入探讨如何避免...

    JPA分页查询与条件分页查询

    总的来说,JPA分页查询和条件分页查询为开发者带来了极大的便利,它减少了对SQL的直接操作,提高了代码的可读性和可维护性。通过合理地运用Spring Data JPA的特性,可以构建出高效、灵活的数据库访问层。在设计和...

    hibernate动态数据库改进版

    Hibernate提供Criteria API,允许开发者在运行时构建查询条件,实现动态SQL。Criteria API基于对象的API,可以更灵活地创建查询。 2.2 HQL(Hibernate Query Language) HQL是Hibernate自己的查询语言,类似SQL但...

    Hibernate查询映射试验

    在这个“Hibernate查询映射试验”项目中,你可能会遇到如何配置SessionFactory、如何创建和执行HQL/Criteria查询、如何处理关联映射(如一对一、一对多、多对多)、如何使用事务管理等实践环节。理解并熟练掌握这些...

    hibernate查询

    在 Hibernate 中进行查询是其核心功能之一,本文将详细介绍 Hibernate 的几种查询方式,包括 HQL (Hibernate Query Language) 查询、QBC (Query By Criteria) 查询以及 QBE (Query By Example) 查询,并结合示例代码...

    防止sql注入解决方案

    框架如Hibernate、MyBatis等在设计时已考虑了SQL注入问题,它们会自动处理预编译语句和参数绑定,减少开发者的安全顾虑。 6. **最小权限原则**: 数据库连接应使用具有最小权限的账户,这样即使发生SQL注入,攻击...

    sql语句中用问号代替参数

    2. **提高性能**:预编译的SQL语句可以在数据库中缓存,多次执行相同结构但不同参数的查询时,可以显著提高执行效率。数据库只需解析一次SQL模板,然后用新参数替换问号即可。 3. **减少错误**:动态构建SQL字符串...

    hibernate源码包

    Criteria API 是一种基于对象的查询方式,可以动态构建查询条件,避免了SQL拼接带来的问题。HQL则是面向对象的查询语言,类似于SQL,但更贴近于Java对象模型,使得查询更为直观。 4. **缓存机制** Hibernate 3.0 ...

Global site tag (gtag.js) - Google Analytics