select SYR,SFZMHM,CJRZH,XSZBH,HPHM,CLSBDH,FDJH,CLLX,ZDYZT,to_char(CCDJRQ,'YYYY-MM-DD') CCDJRQ from VEH_DISABLED   where CCDJRQ between to_date('2013-10-15','yyyy-MM-dd')and to_date('2015-10-15','yyyy-MM-dd') order by CCDJRQ desc

Service里的查询:

public List getAdvancedListService(Map map){
		StringBuilder sqlCondition = new StringBuilder();
		Set keys = map.keySet();
		if (keys.contains("SYR")) {
			if (map.get("SYR") != null && !"".equals(map.get("SYR").toString().trim()) && !"null".equals(map.get("SYR"))) {
				sqlCondition.append("and SYR like '%" + map.get("SYR") + "%'");
			}
		}
		if (keys.contains("SFZMHM")) {
			if (map.get("SFZMHM") != null && !"".equals(map.get("SFZMHM").toString().trim()) && !"null".equals(map.get("SFZMHM"))) {
				sqlCondition.append("and SFZMHM = '" + map.get("SFZMHM") + "'");
			}
		}
		if (keys.contains("CJRZH")) {
			if (map.get("CJRZH") != null && !"".equals(map.get("CJRZH").toString().trim()) && !"null".equals(map.get("CJRZH"))) {
				sqlCondition.append("and CJRZH like '%" + map.get("CJRZH") + "%' ");
			}
		}
		if (keys.contains("XSZBH")) {
			if (map.get("XSZBH") != null && !"".equals(map.get("XSZBH").toString().trim()) && !"null".equals(map.get("XSZBH").toString().trim())) {
				sqlCondition.append("and XSZBH like '%" + map.get("XSZBH") + "%' ");
			}
		}
		if (keys.contains("CLSBDH")) {
			if (map.get("CLSBDH") != null && !"".equals(map.get("CLSBDH").toString().trim()) && !"null".equals(map.get("CLSBDH").toString().trim())) {
				sqlCondition.append("and CLSBDH = '" + map.get("CLSBDH") + "' ");
			}
		}
		if (keys.contains("FDJH")) {
			if (map.get("FDJH") != null && !"".equals(map.get("FDJH").toString().trim()) && !"null".equals(map.get("FDJH").toString().trim())) {
				sqlCondition.append("and FDJH = '" + map.get("FDJH") + "' ");
			}
		}
		if (keys.contains("CLLX")) {
			if (map.get("CLLX") != null && !"".equals(map.get("CLLX").toString().trim()) && !"null".equals(map.get("CLLX").toString().trim())) {
				sqlCondition.append("and CLLX = '" + map.get("CLLX") + "' ");
			}
		}
		if (keys.contains("HPHM")) {
			if (map.get("HPHM") != null && !"".equals(map.get("HPHM").toString().trim()) && !"null".equals(map.get("HPHM"))) {
				sqlCondition.append("and HPHM = '" + map.get("HPHM") + "' ");
			}
		}
		if (keys.contains("loginBeginTime") && keys.contains("loginEndTime")){
			sqlCondition.append("and CCDJRQ between to_date('").append(map.get("loginBeginTime")).append("','yyyy-MM-dd')and to_date('").append(map.get("loginEndTime")).append("','yyyy-MM-dd')");
		}
		if(sqlCondition.length() > 3){
			return disabledvehDao.getAdvancedList(sqlCondition.substring(3));
		}
		    return disabledvehDao.getAdvancedList(sqlCondition.toString());
	}

Dao类:

	/**
	 * 高级查询
	 * @param
	 * @return
	 */
	@SuppressWarnings("rawtypes")
	public List getAdvancedList(String condition){
		String sql;
		if("".equals(condition) || "null".equals(condition) || condition == null){
			sql ="select d.SYR,d.SFZMHM,d.CJRZH,d.XSZBH,d.HPHM,d.CLSBDH,d.FDJH,d.CLLX,d.ZDYZT,to_char(d.CCDJRQ,'YYYY-MM-DD') CCDJRQ"+
			" from VEH_DISABLED d order by d.CCDJRQ desc";
		}else{
			sql = "select d.SYR,d.SFZMHM,d.CJRZH,d.XSZBH,d.HPHM,d.CLSBDH,d.FDJH,d.CLLX,d.ZDYZT,to_char(d.CCDJRQ,'YYYY-MM-DD') CCDJRQ"+
			" from VEH_DISABLED d  where "+condition+" order by d.CCDJRQ desc";
		}
		return jdbcTemplate.queryForList(sql);
	}

provider类:

package com.suntek.disabledvehmgr.web.disabledveh;

import java.util.ArrayList;
import java.util.List;
import java.util.Map;

import javax.servlet.http.HttpServletRequest;

import com.suntek.ccf.web.service.ServiceInvocationException;
import com.suntek.eap.core.app.AppHandle;
import com.suntek.disabledvehmgr.dao.base.BaseGrid;
import com.suntek.disabledvehmgr.log.DisabledvehMgrLogger;
import com.suntek.disabledvehmgr.service.disabledveh.DisabledvehService;
import com.suntek.disabledvehmgr.util.CommonUtil;
import com.suntek.disabledvehmgr.util.Constants;
import com.suntek.disabledvehmgr.util.SpringContextUtils;

/**
 * 残疾车业务provider类
 * @author sawshaw
 *
 */
public class AdvancedQueryProvider extends BaseGrid{

	@SuppressWarnings("unused")
	private AppHandle appHandle;
	private HttpServletRequest request;
	private DisabledvehService disabledvehService;

	@Override
	public void after(HttpServletRequest arg0)
			throws ServiceInvocationException {
	}
	@Override
	public void before(HttpServletRequest request)
			throws ServiceInvocationException {
		this.request = request;
		this.appHandle = AppHandle.getHandle(Constants.APP_NAME);
		this.disabledvehService = (DisabledvehService)
				SpringContextUtils.getBean("disabledvehService",request);
	}
	@SuppressWarnings({ "rawtypes", "unchecked" })
	@Override
	public int directCount(Map map) {
		try{
			if(!CommonUtil.isRequestLegal(request)){
				datas = new ArrayList<Map>();
				return datas.size();
			}
			if("firstLoad".equals(CommonUtil.getKeyValue(map, "opera_type"))){
				return 0;
			}
			if (map != null) {
				datas = disabledvehService.getAdvancedListService(map);
			}
			if(datas == null){
				datas = new ArrayList<Map>();
			}
		}catch(Exception e){
		    	DisabledvehMgrLogger.logger.error("[AdvancedQueryProvider]directCount,查询异常,", e);
			datas = new ArrayList<Map>();
		}
		return datas.size();
	}
	@SuppressWarnings("rawtypes")
	@Override
	public List<Map> directFetch(Map map, int pageNo, int pageSize) {
		if("firstLoad".equals(CommonUtil.getKeyValue(map, "opera_type"))){
			return new ArrayList<Map>();
		}
		return CommonUtil.getPageList(pageNo, pageSize, datas);
	}
}

页面关键部分:

<%@ page language="java" import="java.util.*" contentType="text/html; charset=gbk" pageEncoding="gbk" %>
<%@ taglib uri="http://eaptag.suntek.com" prefix="ui" %>

<%
   String userCode=request.getRemoteUser();
   String path = request.getContextPath();
   if(userCode == null){
		out.println("<script>top.location.href='" + path+ "/index.jsp';</script>");
		return ;
	}

%>
<html>
<head>
	<title>高级查询</title>
	<script type="text/javascript" src="/eaptag2/js/ccftag.form.js"></script>
	<script type="text/javascript" src="/eaptag2/js/ccftag.zdialog.js" ></script>
	<script type="text/javascript" src="<%=path%>/js/common.js" ></script>
	<script type="text/javascript" src="<%=path%>/js/station.util.js" ></script>

	<ui:Import tagNames="Window,Label,DateTimePicker,GTGrid,Button,GTGridField,Select"></ui:Import>
<style type="text/css">
.queryLabel{
 height:19px;
 width: 65px;
 text-align:right;
 padding-top: 2px;
}
</style>
<script type="text/javascript">

var ajax = new ccftag_ajax("<%=path%>/ccftag",false);

$(function(){
	$('input:checkbox').click(function(){
		var _this = $(this);
		if(_this.attr("checked") == true){
			$("input[name='status']").each(function(i){
				$(this).removeAttr("checked");
			});
			_this.attr("checked","checked");
		}else{
			_this.removeAttr("checked");
		}
		doQuery();
	});
});
function doQuery(){
		var param = Form.formToBean(queryForm,"java.util.Map",true);
		if(param.loginEndTime!=''&& param.loginBeginTime=='')
			{
			alert("请选择开始登记日期!");
			return ;
			}
		if(param.logiBeginTime!=''&& param.loginEndTime=='')
		{
		alert("请选择结束登记日期!");
		return ;
		}
		if(param.loginEndTime < param.loginBeginTime){
			alert("开始登记日期必须小于结束登记日期!");
			return ;
		}
		param.SYR = $("#queryName").val();
		param.SFZMHM = $("#queryIdNo").val();
		param.CJRZH = $("#queryDisabledNo").val();
		param.XSZBH = $("#queryTravelNo").val();
		param.HPHM = $("#queryVehNo").val();
		param.CLSBDH = $("#queryChassisNo").val();
		param.FDJH = $("#queryEngineNo").val();
		param.CLLX= $("#queryBrand").val();
		param.loginBeginTime= $("#loginBeginTime").val();
		param.loginEndTime= $("#loginEndTime").val();
		param.status = getSelectStatus();
		var map = disabledGrid.resetParameter(20,param);
		ajax.remoteCall("bean://com.suntek.disabledvehmgr.web.disabledveh.AdvancedQueryProvider:getData",[map],function(reply){
			//alert(reply.getResult());
			disabledGrid.cleanContent();
			disabledGrid.setContent(eval("(" + reply.getResult() + ")"));
		});
}
 function getSelectStatus(){
	var status = "";
	var $statusObj = $("input[name='status']:checked");
	$statusObj.each(function(i){
		status += $statusObj.eq(i).val() + ",";
	});
	if(status.length > 0){
		status = status.substring(0, status.length-1);
	}
	return status;
}
</script>
</head>
<body style="margin: 0px; overflow: hidden;" scroll="no">

	 <ui:Window id="winVehicleList" title=""  style="width:100%;height:100%;table-layout:fixed;" >
		<ui:Window.head>
			<form id="queryForm">
				<input type="hidden" id="BOOKING_TYPE" name="BOOKING_TYPE" value="4"/>
				<label class="queryLabel">登记日期:</label>
				<ui:DateTimePicker id="loginBeginTime" dateFmt="yyyy-mm-dd" value="2013-10-15" style="width:100px" readOnly="true"></ui:DateTimePicker>
				至<ui:DateTimePicker id="loginEndTime" dateFmt="yyyy-mm-dd" value="2014-12-15" style="width:100px" readOnly="true"></ui:DateTimePicker>
				<label class="queryLabel">姓名:</label><input type="text" id="queryName" style="width:106px;"/>
				<label class="queryLabel">身份证号:</label><input type="text" id="queryIdNo" style="width: 166px;"/>
				<label class="queryLabel">行驶证号:</label><input type="text" id="queryTravelNo" style="width:136px;"/><br/><br/>
				<label class="queryLabel">残疾证号:</label><input type="text" id="queryDisabledNo" style="width:136px;"/>
				<label class="queryLabel">车牌号:</label><input type="text" id="queryVehNo" style="width:106px;"/>
				<label class="queryLabel">车架号:</label><input type="text" id="queryChassisNo" style="width:106px;"/>
				<label class="queryLabel">发动机号:</label><input type="text" id="queryEngineNo" style="width:106px;"/>
				<label class="queryLabel">厂牌型号:</label><input type="text" id="queryBrand" style="width:106px;"/>
				    
				<ui:Button cls="query" onClick="doQuery()">查询</ui:Button>
			</form><hr/>
		</ui:Window.head>
  		<ui:Window.body id="winBlackListGrid" style="width:100%;height:100%">
				<ui:GTGrid id="disabledGrid"
					rowNumPerPage="20"
					css="width:100%; height:100%;"
					uniqueField="ID"
				  	exportSupport="true"
				  	autoLoad="false"
					dataProvider="bean://com.suntek.disabledvehmgr.web.disabledveh.AdvancedQueryProvider:getData">
					<%-- <ui:GTGridField name="ID" header="序号" isChecked="true"/> --%>
					<ui:GTGridField name="SYR" header="姓名" fieldType="string" align="left" width="100"/>
					<ui:GTGridField name="SFZMHM" header="身份证号" fieldType="string" align="center" width="150"/>
					<ui:GTGridField name="XSZBH" header="行驶证号" fieldType="string" align="center" width="120"/>
					<ui:GTGridField name="CJRZH" header="残疾证号" fieldType="string" align="center" width="120"/>
					<ui:GTGridField name="HPHM" header="车牌号" fieldType="string" align="center" width="120"/>
					<ui:GTGridField name="CLSBDH" header="车架号" fieldType="string" align="center" width="80"/>
					<ui:GTGridField name="FDJH" header="发动机号" fieldType="string" align="center" width="80"/>
					<ui:GTGridField name="CLLX" header="厂牌型号" fieldType="string" align="center" width="80"/>
					<ui:GTGridField name="ZDYZT" header="状态" fieldType="string" align="center" width="80"/>
					<ui:GTGridField name="CCDJRQ" header="登记日期" fieldType="string" align="center" width="120"/>
				<%-- 	<ui:GTGridField name="Files" header="申请资料电子影像文件" fieldType="string" align="center" width="140"/>	 --%>
				</ui:GTGrid>
  		</ui:Window.body>
  	</ui:Window>
  	<!-- <iframe name="downloadFrame" border='0' width='0' height='0'></iframe> -->
</body>
</html>

JAVA 中SQL字符动态拼接的更多相关文章

  1. [转帖]关于Java中SQL语句的拼接规则

    关于Java中SQL语句的拼接规则 自学demo 的时候遇到的问题 结果应该是 '"+e.getName()+"' 注意 一共有三组标点符号 (除去 方法函数后面的括号) 实现目标 ...

  2. 关于Java中SQL语句的拼接规则

    实现目标语句是这个注意,这里的java变量是idd int idd; String sql = "SELECT id, piUrl FROM picinfos WHERE id BETWEE ...

  3. java中sql语句能不能加分号的问题?

    一.原因  在程序运行中,当执行sql后总是报无效字符错误:但是把程序放在pl/sql中执行又没有错误.让我很纳闷!于是我开始查找资料,然后我终于发现了问题. 二.问题剖析 原来在程序中:如果你在程序 ...

  4. Java中面向字符的输入流

    Java中面向字符的输入流 2016-12-04 Java程序员联盟 Java程序员联盟 Java程序员联盟 微信号 javalm 功能介绍 莫道君行早,更有早行人 全心敲代码,天道自酬勤 字符流是针 ...

  5. java中的字符集和编码

    前言 上次对计算机中的“字符集”和“编码”分别进行了总结,并指出二者之间的区别,不要搞混了,不清楚的再回到上一章看一下.今天再总结下java中是如何使用字符集(主要是Unicode字符集,其他常用字符 ...

  6. Java中的JDK动态代理

    所谓代理,其实就是相当于一个中间人,当客户端需要服务端的服务时,不是客户直接去找服务,而是客户先去找代理,告诉代理需要什么服务,然后代理再去服务端找服务,最后将结果返回给客户. 在日常生活中,就拿买火 ...

  7. Java中sql语句的引号问题

    1..sql语句 在数据库中,当我们查询语句时,会使用类似的语句: Select * from userinfo where userid='1' or 1; Select * from userin ...

  8. 【Java编程】Java中的字符串匹配

    在Java中,字符串的匹配可以使用下面两种方法:         1.使用正则表达式判断字符串匹配         2.使用Pattern类和Matcher类判断字符串匹配 正则表达式的字符串匹配: ...

  9. JAVA中Sql时间格式与util时间格式转换

    关于时间格式转化: java.util.Date 与 java.sql.Date 互换 sql是子类 字符串转化成java.util.Date     SimpleDateFormat date =n ...

随机推荐

  1. Mac下Android Studio中获取SHA1和MD5

    有很多人讲这个的时候,老是只把这个代码标出来又不说为什么 keytool -list -keystore debug.keystore keytool   这个是java的 jdk中一个工具(做签名文 ...

  2. Spring AOP 针对注解的AOP

    我也忘记是从哪里扒来的代码,不过有了这个思路,以后可以自己针对 Controller 还有 Service层的任意 方法进行代理了 package pw.jonwinters.aop; import ...

  3. 一道看似简单的sql需求却难倒各路高手 - 你也来挑战下吗?

    转自:http://www.cnblogs.com/keguangqiang/p/4535046.html 听说这题难住大批高手,你也来试下吧.ps:博问里的博友提出的. 原始数据 select *  ...

  4. Linux 发送信号

    使用kill命令 --在命令行执行kill命令.向指定进程发送信号. 使用kill函数 int kill(pid_t pid,int sig); --参数pid指定一个要杀死的进程,而sig是要发送的 ...

  5. js计算两个日期相隔几小时几分钟?

        var dt1 = "2009-11-5 10:30"       var dt2 = "2009-11-8 9:20"     function ge ...

  6. freemarker语法简介

    ftl是一种模板标记语言,用于渲染数据,输入html结构.语法简介如下: ${book.name} ${book.name?if_exists} //值是否存在 ${book.name??} //值是 ...

  7. 虚拟机安装Mac OS X ----- VM12安装Mac OS X

    Windows下虚拟机安装Mac OS X -– VM12安装Mac OS X 10.11 随着Iphone在国内大行其道,越来越多的开发者涌入iOS开发大军 中,但都苦于没有苹果机,本文即将介绍WI ...

  8. 做leetcode的几点体会分享(转)

    1 大部分题目你都是可以自己做出来的.所以,第一遍尽量不要网上找答案: 2 写了的不管通过的,不通过的答案要保存下来.不通过的,也要记录下来哪儿没有通过.很有可能你这次错了,不知道怎么搞过了,下次还是 ...

  9. Bootstrap Paginator 分页插件参数介绍及使用

    Bootstrap Paginator是一款基于Bootstrap的js分页插件,功能很丰富,个人觉得这款插件已经无可挑剔了.它提供了一系列的参数用来支持用户的定制,提供了公共的方法可随时获得插件状态 ...

  10. Quartz.NET syudy

    Quartz.NET   Quartz.NET是一个开源的作业调度框架,是OpenSymphony 的 Quartz API的.NET移植,它用C#写成,可用于winform和asp.net应用中.它 ...