作了一年的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的时候老师对这个运算只是简单一提没有想到这个运算符会在这里给你省这么多麻烦。