自制xml实现SQL动态参数配置
此文章是基于 搭建Jquery+SpringMVC+Spring+Hibernate+MySQL平台
一. jar包介绍
1. commons-digester3-3.2.jar
2. commons-beanutils-1.9.3.jar
二. 类介绍
1. SqlXmlParser.java,xml 解析器
package com.ims.persistence.base; import java.io.File;
import java.io.FileInputStream;
import java.io.InputStream;
import java.text.MessageFormat;
import java.util.ArrayList;
import java.util.List;
import java.util.Map; import org.apache.commons.digester3.Digester;
import org.apache.commons.lang3.StringUtils;
import org.apache.log4j.Logger; public class SqlXmlParser {
private String sqlXml;
private static Digester digester; private static String webrootPath = System.getProperty("webapp.root")+"sql/";
private static Logger logger = Logger.getLogger(SqlXmlParser.class); static{
digester = new Digester();
digester.setValidating(false); digester.addObjectCreate("set", SqlSet.class); digester.addObjectCreate("set/sql", Sql.class);
digester.addSetProperties("set/sql");
digester.addBeanPropertySetter("set/sql/pattern");
digester.addSetNext("set/sql", "addSql"); digester.addObjectCreate("set/sql/param", SqlParam.class);
digester.addSetProperties("set/sql/param");
digester.addSetNext("set/sql/param", "addParam");
} public SqlXmlParser(String sqlXml){
this.sqlXml = sqlXml;
} public String parse(String sqlName, Map<String, String> params){
InputStream is = null;
String result = null;
try{
is = new FileInputStream(new File(webrootPath+sqlXml));
SqlSet sqlSet = (SqlSet)digester.parse(is);
Sql sql = sqlSet.getSqls().get(sqlName);
List<String> paramList = new ArrayList<String>();
for(SqlParam param : sql.getCondition()){
String value = params.get(param.getName());
paramList.add(param.getPosition(), StringUtils.isBlank(value)?"":value);
}
result = MessageFormat.format(sql.getPattern(), paramList.toArray());
}catch(Exception e1){
logger.error("sql文件解析异常:"+e1);
}finally {
if(is != null) {
try {
is.close();
}catch (Exception e2) {
logger.error("sql文件流关闭异常:"+e2);
} is = null;
digester.clear();
}
} return result;
}
}
2. SqlSet.java
package com.ims.persistence.base; import java.util.HashMap;
import java.util.Map; public class SqlSet {
private Map<String, Sql> sqls = new HashMap<String, Sql>(); public void addSql(Sql sql){
sqls.put(sql.getName(), sql);
} public Map<String, Sql> getSqls() {
return sqls;
}
public void setSqls(Map<String, Sql> sqls) {
this.sqls = sqls;
}
}
3. Sql.java
package com.ims.persistence.base; import java.util.ArrayList;
import java.util.List; public class Sql{
private String name;
private String pattern;
private List<SqlParam> condition = new ArrayList<SqlParam>(); public void addParam(SqlParam param){
condition.add(param);
} public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
} public String getPattern() {
return pattern;
}
public void setPattern(String pattern) {
this.pattern = pattern;
} public List<SqlParam> getCondition() {
return condition;
}
public void setCondition(List<SqlParam> condition) {
this.condition = condition;
}
}
4. SqlParam.java
package com.ims.persistence.base; public class SqlParam {
private String name;
private Integer position; public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
} public Integer getPosition() {
return position;
}
public void setPosition(Integer position) {
this.position = position;
}
}
三. 使用方法介绍
1. WebContent/sql 下创建包含sql语句的xml文件,例如:
<?xml version="1.0" encoding="utf-8" ?>
<set>
<sql name="codeType">
<pattern>
<![CDATA[
select A.id, A.value, A.text
from sys.code A
left join sys.codeType B on A.codeTypeId = B.id
where (case when "{0}"="" then 1=1 else B.codeType = "{0}" end)
and (case when "{1}"="" then 1=1 else A.isEnable = "{1}" end)
and (case when "{2}"="" then 1=1 else A.isDefault = "{2}" end)
]]>
</pattern> <param name="codeType" position="0" />
<param name="isEnable" position="1" />
<param name="isDefault" position="2" /> </sql>
</set>
2. 类中使用,例如:
public class CodeBSImpl implements CodeBS{
private static final String sqlXml = "sys/code.xml"; @Override
public List<Map<String, Object>> getValueTextListByType(String codeType) {
Map<String, String> paramMap = new HashMap<String, String>();
paramMap.put("codeType", codeType);
List<Map<String, Object>> list = codeDao.findBySql(new SqlXmlParser(sqlXml).parse("codeType", paramMap));
List<Map<String, Object>> result = new ArrayList<Map<String, Object>>();
for(Map<String, Object> map:list){
Map<String, Object> temp = new HashMap<String, Object>();
temp.put("value", map.get("value"));
temp.put("text", map.get("text"));
result.add(temp);
}
return result;
} }
自制xml实现SQL动态参数配置的更多相关文章
- mybatis由浅入深day01_6SqlMapConfig.xml(6.2settings全局参数配置_6.3typeAliases(类型别名)_6.4typeHandlers(类型处理器)_6.5mappers(映射配置))
6 SqlMapConfig.xml mybatis的全局配置文件SqlMapConfig.xml,配置内容和顺序如下: properties(属性) settings(全局配置参数) typeAli ...
- [sql]mysql参数(配置)手册
my-innodb-heavy-4G.cnf配置文件注解 [client] #客户端 port = 3306 #mysql客户端连接时的默认端口号 socket = /application/mysq ...
- Spark2 SQL configuration参数配置
查看当前环境SQL参数的配置 spark.sql("SET -v") key value spark.sql.hive.version 1.2.1 spark.sql.source ...
- Java的sql动态参数
在C#的方法中可以使用params Parameter[] values来动态获取sql语句中的参数值数组.Java中可以自己封装出一个类似于C#的方法 1.获取结果集 /** * 获取结果集 * @ ...
- 01_MyBatis EHCache集成及所需jar包,ehcache.xml配置文件参数配置及mapper中的参数配置
1 与mybatis集成时需要的jar ehcache-core-2.6.5.jar mybatis-ehcache-1.0.2.jar Mybatis.日志.EHCache所需要的jar包如下 ...
- SQL动态配置,动态解析SQL
在项目中使用SQL动态配置的方式可以让后期的维护和发布后的修改变得更加方便,无论使用那种配置方式都离不开解析成最终真正能执行的SQL.下面代码就是一种比较简单的处理方法,SQL的参数以##括起来. 1 ...
- redis动态修改参数配置
./redis-cli -h 10.10.10.11 -p 6401 save # 保存当前快照 # 列出所有当前配置 config get * # 查看指定配置 config get ...
- mybatis 动态sql和参数
mybatis 动态sql 名词解析 OGNL表达式 OGNL,全称为Object-Graph Navigation Language,它是一个功能强大的表达式语言,用来获取和设置Java对象的属性, ...
- MySQL中limit使用动态参数的解决方法(拼接SQL字符串语句来执行SQL)
官方好像说过limit已经在5.6版本上支持了动态参数,但是测试时依然还是不行. 那么要解决limit动态参数唯一能做的就是使用字符串SQL拼接的形式,然后再进行执行. 一般有以下方式解决: 1.存储 ...
随机推荐
- C++11网络编程
Handy是一个简洁优雅的C++11网络库,适用于linux与Mac平台.十行代码即可完成一个完整的网络服务器. 下面是echo服务器的代码: #include <handy/handy.h&g ...
- 让你在PC上调试Web App,UC浏览器发布开发者版
目前,在手机上使用浏览器访问网页,无法便捷地进行网页语言调试.手机屏幕相对较小且操作不便,直接在手机上进行网页数据调试不太现实. 因此,UC使用技术将手机网页调试信息分离,实现一种能在大屏幕.高配置P ...
- ERP程序开发中遇到的六种错误
经常回顾同事写的代码,发现一些问题,总结分析,用于员工培训,或系统优化方面的内容教学. 文中有问题的的代码我用黑体字标识. 1 界面与逻辑代码混淆 这是目前发现的比较严重的问题.框架花费了很大的力气, ...
- 06.GitHub实战系列~6.过滤器过滤掉的文件如何上传
比如我想发布一个软件版本供普通人下载: Git库建立了VS的过滤规则后 dll 和 exe 是自动过滤的,这时候我们得加参数(看图)git add xxx -f
- Android okHttp网络请求之Json解析
前言: 前面两篇文章介绍了基于okHttp的post.get请求,以及文件的上传下载,今天主要介绍一下如何和Json解析一起使用?如何才能提高开发效率? okHttp相关文章地址: Android o ...
- ng-directive-选择数据
本文是用angularjs指令写的一个简易数据选择功能,其实就是两个下拉框,把两边的数据相互交换而已,这样的功能最早应该是用jquery写过,但移动端js框架angularjs如果还嵌套jquery来 ...
- SIHA环境修改主机名实施步骤
目 录 1 实施需求 2 修改主机名 2.1 停止HAS服务 2.2 修改主机名 3 重新配置服务 3.1 使用root用户重新配置CSS & OHAS服务 3.2 设置cssd自动启动属性 ...
- 自己动手之使用反射和泛型,动态读取XML创建类实例并赋值
前言: 最近小匹夫参与的游戏项目到了需要读取数据的阶段了,那么觉得自己业余时间也该实践下数据相关的内容.那么从哪入手呢?因为用的是Unity3d的游戏引擎,思来想去就选择了C#读取XML文件这个小功能 ...
- 简简单单学会C#位运算
一.理解位运算 要学会位运算,首先要清楚什么是位运算?程序中的所有内容在计算机内存中都是以二进制的形式储存的(即:0或1),位运算就是直接对在内存中的二进制数的每位进行运算操作 二.理解数字进制 上面 ...
- Navisworks API 简单二次开发 (自定义工具条)
在Navisworks软件运行的时候界面右侧有个工具条.比较方便.但是在二次开发的时候我不知道在Api那里调用.如果有网友知道请告诉我.谢谢. 我用就自己设置一个工具.界面比较丑!没有美工. 代码: ...