Java生成 sql查询语句 通用方法(带排序/分页)
发布时间:2020-05-30 15:53:42 所属栏目:Java 来源:互联网
导读:Java生成 sql查询语句 通用方法(带排序/分页)
|
下面是脚本之家 jb51.cc 通过网络收集整理的代码片段。 脚本之家小编现在分享给大家,也给大家做个参考。 package com.wuhx.util;
public class SqlParameter {
private String tableName; //物理表名
private Integer minrow = 1; //分页最小行[默认1]
private Integer maxrow; //分页最大行
private String[] orderBy; //排序eg: {"columnA","columnB DESC"}
public Integer getMinrow() {
return minrow;
}
public void setMinrow(Integer minrow) {
this.minrow = minrow;
}
public Integer getMaxrow() {
return maxrow;
}
public void setMaxrow(Integer maxrow) {
this.maxrow = maxrow;
}
public String[] getOrderBy() {
return orderBy;
}
public void setOrderBy(String[] orderBy) {
this.orderBy = orderBy;
}
public String getTableName() {
return tableName;
}
public void setTableName(String tableName) {
this.tableName = tableName;
}
}
/**
*
* @param obj SQL参数
* @param param 分页/排序参数
* @return
* @throws Exception
*/
public static String createSQL(Object obj,SqlParameter param) throws Exception {
StringBuilder sb = new StringBuilder("SELECT t.* FROM "+param.getTableName()+" t WHERE 1=1 ");
Field[] fields = obj.getClass().getDeclaredFields();
for(Field f: fields){
f.setAccessible(true);
Object fName = f.getName();
Object fValue = f.get(obj);
if(fValue != null && !fValue.equals("")){
sb.append(" AND t."+fName+" = '"+fValue+"'");
}
f.setAccessible(false);
}
if(param.getOrderBy() != null){
String orderStr = " ORDER BY ";
for(String str:param.getOrderBy()){
orderStr += " "+str+",";
}
orderStr = orderStr.substring(0,orderStr.length()-1);
sb.append(orderStr);
}
if((param.getMinrow() != null) && (param.getMaxrow() != null)){
StringBuilder sb2 = new StringBuilder("SELECT * FROM ( SELECT A.*,ROWNUM RN FROM ( ");
sb2.append(sb.toString());
sb2.append( " ) A WHERE ROWNUM <= "+param.getMaxrow()+" ) WHERE RN >= "+param.getMinrow() );
sb = sb2;
}
return sb.toString();
}
Teacher t = new Teacher();
t.setTeaId(123456789);
//t.setTeaLevel("副教授");
//t.setTeaName("王老师");
SqlParameter p = new SqlParameter();
p.setTableName("PROPAGANDA_LOG");
p.setOrderBy(new String[]{"columnA","columnB DESC"});
p.setMaxrow(10);
p.setMinrow(5);
System.out.println(createSQL(t,p));
SELECT * FROM ( SELECT A.*,ROWNUM RN FROM ( SELECT t.* FROM PROPAGANDA_LOG t WHERE 1=1 AND t.teaId = '123456789' ORDER BY columnA,columnB DESC ) A WHERE ROWNUM <= 10 ) WHERE RN >= 5 Student s = new Student();
s.setStuAge("18");
s.setStuName("张三");
SqlParameter p = new SqlParameter();
p.setTableName("STUDENT_LOG");
System.out.println(createSQL(s,p));
SELECT t.* FROM STUDENT_LOG t WHERE 1=1 AND t.stuName = '张三' AND t.stuAge = '18' 以上是脚本之家(jb51.cc)为你收集整理的全部代码内容,希望文章能够帮你解决所遇到的程序开发问题。 如果觉得脚本之家网站内容还不错,欢迎将脚本之家网站推荐给程序员好友。 (编辑:安卓应用网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
