加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > Java > 正文

Java生成 sql查询语句 通用方法(带排序/分页)

发布时间:2020-12-15 03:19:40 所属栏目:Java 来源:网络整理
导读:今天PHP站长网 52php.cn把收集自互联网的代码分享给大家,仅供参考。 package com.wuhx.util;public class SqlParameter {private String tableName; //物理表名private Integer minrow = 1; //分页最小行[默认1]private

以下代码由PHP站长网 52php.cn收集自互联网

现在PHP站长网小编把它分享给大家,仅供参考

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'

以上内容由PHP站长网【52php.cn】收集整理供大家参考研究

如果以上内容对您有帮助,欢迎收藏、点赞、推荐、分享。

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读