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

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

在作数据库条件查询时有时会遇到几种条件的组合查询,对于这种情况下的SQL语句的生成一般的方法是不行的。在本文中用?:三元运算符解决这个问题。尽管在软件工程里经常有批判这种运算符的使用,认为这种运算符的使用降低了代码的清晰度,但本人感觉这种方法还是值的一提。
       
作了一年的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语句生成)