zoukankan      html  css  js  c++  java
  • 自制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;
        }
    }
    View Code

      

      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;
        }
    }
    View Code

      

      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;
        }
    }
    View Code

      

      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;
        }
    }
    View Code

      

    三. 使用方法介绍  

      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>
    View Code

      

      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;
        }
    
    }
    View Code
  • 相关阅读:
    ASP.NET WebApi 文档Swagger中度优化
    ASP.NET五步打包下载Zip文件
    JavaScript——HashMap实现
    JS实现集合和ECMA6集合
    JavaScript——双向链表实现
    用JavaScript来实现链表LinkedList
    JavaScript结构三层——思想快速介绍
    浏览器自动刷新——基于Nodejs的Gulp LiveReload与VisualStudio完美结合。
    JavaScript原型OOP——你上车了吗?
    再谈JavaScript闭包及应用
  • 原文地址:https://www.cnblogs.com/Mr-kevin/p/6151099.html
Copyright © 2011-2022 走看看