多项查询条件组合下的SQL语句生成

原创 2006年05月25日 19:38:00

        作了一年的WEB应用,在这里面无疑核心就是数据的出出进进。而在作数据条件查询时,经常会遇到多项查询条件的组合,对于这种情况下SQL语句的生成经过这么长时间的实践加思考,最终给自己定下了一个规范性的编写方法。

举例如下:

现有数据库表,表名:student,表内字段如下:ID,GENDER,NAME,NUM,CLASSID。

有时会遇到的查询条件会是GENDER,NAME,NUM,CLASSID的任意组合,即每一项条件用户可以填也可以不填,如果按每一项条件字段NULL  OR  NOT   NULL 来组合的话,会有16种情况。过去类似条件只是两项的情况下一般会用一种比较BC的办法就是根据这几种组合分别生成对应的SQL语句,但后来遇到一次比较郁闷的情况是查询条件到了6个,上种方法的可行性可想而知。

对于上例可以用如下构造方法(JAVA)。

String sql = " SELECT * FORM student WHERE " +

                     " ID = " + (ID.equals("")?"ID":ID) +

                     " AND GENDER = " + (GENDER.equals("")?"GENDER":GENDER) +

                     " AND NAME = " + (NAME.equals("")?"NAME":NAME) +

                     " AND NUM = " + (NUM.equals("")?"NUM":NUM) +

                     " AND CLASSID = " + (CLASSID.equals("")?"CLASSID":CLASSID);

        在这里用到了?:三元运算符,在刚学JAVA的时候老师对这个运算只是简单一提没有想到这个运算符会在这里给你省这么多麻烦。

动态SQL查询,组合查询

本文通过在SQL语句select 全部查询尾部添加where 1=1 ,从而实现后期条件拼接的便利,可以无限次添加 and =* and = and… … 这样,就能通过传入参数不同实现不同的查询/...
  • Amen_Wu
  • Amen_Wu
  • 2016年12月01日 18:35
  • 1798

SQL连接查询语句(内、外、交叉和合并查询)

接触Sql语句时间挺长时间了,听他人说过sql语句的连接查询,但一直没有认真研究和使用过!!最近在公司实习,需要用到一些连接的语句,我也从中体会到连接查询带来的方便。 下面总结一下SQL连接查询...
  • u010011371
  • u010011371
  • 2016年01月27日 20:49
  • 4630

sql查询 ,多行数据合并成一行,并且显示合并后某一列的值拼接结果

使用stuff + for xml path 解决sql查询 order by之后拼接列,并显示拼接后的字符串
  • u012860938
  • u012860938
  • 2016年03月04日 16:49
  • 13575

XsqlFilterResult----动态生成sql语句的类,过滤一些为空的查询条件

XsqlBuilder用于可以动态构造sql语句,避免在构造sql时使用过多的 if 判断,与SafeSqlProcesser集成提供防止sql注入攻击,与DataModifier集成完成数据类型的转...
  • wwwqqeew
  • wwwqqeew
  • 2012年11月25日 11:10
  • 785

XsqlFilterResult----动态生成sql语句的类,过滤一些为空的查询条件 .

XsqlBuilder用于可以动态构造sql语句,避免在构造sql时使用过多的 if 判断,与SafeSqlProcesser集成提供防止sql注入攻击,与DataModifier集成完成数据类型的转...
  • wyt4455
  • wyt4455
  • 2013年03月25日 16:15
  • 454

通用SQL数据查询条件生成程序Delphi版

  • 2010年06月19日 14:42
  • 14KB
  • 下载

通用的可带查询条件的SQL语句的分页存储过程(2)

代码二: CREATE PROCEDURE pagination @tblName varchar(255), – 表名 @strGetFields varchar(1000) = ‘...
  • tlammon
  • tlammon
  • 2016年03月25日 10:10
  • 876

RailsCasts中文版,#15 Fun with Find Conditions 使用hash为查询条件以便生成正确语法的SQL查询

这次我们来讨论一下关于find方法查询条件的话题。以下是Rails Console输出的SQL查询语句。对应的动作是查找所有优先级为3的未完成任务。 >>Task.count(:all,:c...
  • ABBuggy
  • ABBuggy
  • 2012年11月25日 11:32
  • 1554

SQL Server交叉查询存储过程实现(带查询条件)

  • 2013年04月16日 17:27
  • 82KB
  • 下载

报表票据打印/建立SQL查询条件/数据功能扩张

  • 2006年02月23日 09:05
  • 1.35MB
  • 下载
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:多项查询条件组合下的SQL语句生成
举报原因:
原因补充:

(最多只允许输入30个字)