亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? sqlmapparser.java

?? 本套系統采用了業界當前最為流行的beanAction組件
?? JAVA
?? 第 1 頁 / 共 2 頁
字號:
package com.ibatis.sqlmap.engine.builder.xml;

import com.ibatis.common.logging.Log;
import com.ibatis.common.logging.LogFactory;
import com.ibatis.common.resources.Resources;
import com.ibatis.common.xml.Nodelet;
import com.ibatis.common.xml.NodeletException;
import com.ibatis.common.xml.NodeletParser;
import com.ibatis.common.xml.NodeletUtils;

import com.ibatis.sqlmap.client.extensions.TypeHandlerCallback;
import com.ibatis.sqlmap.engine.cache.CacheModel;
import com.ibatis.sqlmap.engine.mapping.parameter.BasicParameterMap;
import com.ibatis.sqlmap.engine.mapping.parameter.BasicParameterMapping;
import com.ibatis.sqlmap.engine.mapping.result.*;
import com.ibatis.sqlmap.engine.mapping.statement.*;
import com.ibatis.sqlmap.engine.type.CustomTypeHandler;
import com.ibatis.sqlmap.engine.type.TypeHandler;
import org.w3c.dom.Node;

import java.io.InputStream;
import java.io.Reader;
import java.util.ArrayList;
import java.util.List;
import java.util.Properties;
import java.util.StringTokenizer;
import java.util.Iterator;

public class SqlMapParser extends BaseParser {

  private static final Log log = LogFactory.getLog(SqlMapParser.class);

  protected final NodeletParser parser = new NodeletParser();

  public SqlMapParser(Variables vars) {
    super(vars);
    parser.setValidation(true);
    parser.setEntityResolver(new SqlMapClasspathEntityResolver());

    addSqlMapNodelets();
    addSqlNodelets();
    addTypeAliasNodelets();
    addCacheModelNodelets();
    addParameterMapNodelets();
    addResultMapNodelets();
    addStatementNodelets();

  }

  public void parse(Reader reader) throws NodeletException {
    parser.parse(reader);
  }

  public void parse(InputStream inputStream) throws NodeletException {
    parser.parse(inputStream);
  }

  private void addSqlMapNodelets() {
    parser.addNodelet("/sqlMap", new Nodelet() {
      public void process(Node node) throws Exception {
        Properties attributes = NodeletUtils.parseAttributes(node, vars.properties);
        vars.currentNamespace = attributes.getProperty("namespace");
      }
    });
    parser.addNodelet("/sqlMap/end()", new Nodelet() {
      public void process(Node node) throws Exception {
        Iterator names = vars.delegate.getResultMapNames();
        while (names.hasNext()) {
          String name = (String)names.next();
          ResultMap rm = vars.delegate.getResultMap(name);
          Discriminator disc = rm.getDiscriminator();
          if (disc != null) {
            disc.bindSubMaps();
          }
        }
      }
    });
  }

  private void addSqlNodelets() {
    parser.addNodelet("/sqlMap/sql", new Nodelet() {
      public void process(Node node) throws Exception {
        Properties attributes = NodeletUtils.parseAttributes(node, vars.properties);
        String id = attributes.getProperty("id");
        if (vars.useStatementNamespaces) {
          id = applyNamespace(id);
        }
        if (vars.sqlIncludes.containsKey(id)) {
          // To be upgraded to throwing of a RuntimeException later on
          log.warn("Duplicate <sql>-include '" + id + "' found.");
        }
        else  {
        	vars.sqlIncludes.put(id, node);
        }
      }
    });
  }

  private void addTypeAliasNodelets() {
    parser.addNodelet("/sqlMap/typeAlias", new Nodelet() {
      public void process(Node node) throws Exception {
        Properties prop = NodeletUtils.parseAttributes(node, vars.properties);
        String alias = prop.getProperty("alias");
        String type = prop.getProperty("type");
        vars.typeHandlerFactory.putTypeAlias(alias, type);
      }
    });
  }

  private void addCacheModelNodelets() {
    parser.addNodelet("/sqlMap/cacheModel", new Nodelet() {
      public void process(Node node) throws Exception {
        vars.currentCacheModel = new CacheModel();
        vars.currentProperties = new Properties();
      }
    });
    parser.addNodelet("/sqlMap/cacheModel/end()", new Nodelet() {
      public void process(Node node) throws Exception {
        vars.errorCtx.setActivity("building a cache model");

        Properties attributes = NodeletUtils.parseAttributes(node, vars.properties);
        String id = applyNamespace(attributes.getProperty("id"));
        String type = attributes.getProperty("type");
        type = vars.typeHandlerFactory.resolveAlias(type);

        String readOnly = attributes.getProperty("readOnly");
        if (readOnly != null && readOnly.length() > 0) {
          vars.currentCacheModel.setReadOnly("true".equals(readOnly));
        } else {
          vars.currentCacheModel.setReadOnly(true);
        }

        String serialize = attributes.getProperty("serialize");
        if (serialize != null && serialize.length() > 0) {
          vars.currentCacheModel.setSerialize("true".equals(serialize));
        } else {
          vars.currentCacheModel.setSerialize(false);
        }

        vars.errorCtx.setObjectId(id + " cache model");

        vars.errorCtx.setMoreInfo("Check the cache model type.");
        vars.currentCacheModel.setId(id);
        vars.currentCacheModel.setResource(vars.errorCtx.getResource());

        try {
          vars.currentCacheModel.setControllerClassName(type);
        } catch (Exception e) {
          throw new RuntimeException("Error setting Cache Controller Class.  Cause: " + e, e);
        }

        vars.errorCtx.setMoreInfo("Check the cache model configuration.");
        vars.currentCacheModel.configure(vars.currentProperties);

        if (vars.client.getDelegate().isCacheModelsEnabled()) {
          vars.client.getDelegate().addCacheModel(vars.currentCacheModel);
        }

        vars.errorCtx.setMoreInfo(null);
        vars.errorCtx.setObjectId(null);
        vars.currentProperties = null;
        vars.currentCacheModel = null;
      }
    });
    parser.addNodelet("/sqlMap/cacheModel/property", new Nodelet() {
      public void process(Node node) throws Exception {
        vars.errorCtx.setMoreInfo("Check the cache model properties.");
        Properties attributes = NodeletUtils.parseAttributes(node, vars.properties);
        String name = attributes.getProperty("name");
        String value = NodeletUtils.parsePropertyTokens(attributes.getProperty("value"), vars.properties);
        vars.currentProperties.put(name, value);
      }
    });
    parser.addNodelet("/sqlMap/cacheModel/flushOnExecute", new Nodelet() {
      public void process(Node node) throws Exception {
        vars.errorCtx.setMoreInfo("Check the cache model flush on statement elements.");
        Properties childAttributes = NodeletUtils.parseAttributes(node, vars.properties);
        vars.currentCacheModel.addFlushTriggerStatement(childAttributes.getProperty("statement"));
      }
    });
    parser.addNodelet("/sqlMap/cacheModel/flushInterval", new Nodelet() {
      public void process(Node node) throws Exception {
        Properties childAttributes = NodeletUtils.parseAttributes(node, vars.properties);
        long t = 0;
        try {
          vars.errorCtx.setMoreInfo("Check the cache model flush interval.");
          String milliseconds = childAttributes.getProperty("milliseconds");
          String seconds = childAttributes.getProperty("seconds");
          String minutes = childAttributes.getProperty("minutes");
          String hours = childAttributes.getProperty("hours");
          if (milliseconds != null) t += Integer.parseInt(milliseconds);
          if (seconds != null) t += Integer.parseInt(seconds) * 1000;
          if (minutes != null) t += Integer.parseInt(minutes) * 60 * 1000;
          if (hours != null) t += Integer.parseInt(hours) * 60 * 60 * 1000;
          if (t < 1) throw new RuntimeException("A flush interval must specify one or more of milliseconds, seconds, minutes or hours.");
          vars.currentCacheModel.setFlushInterval(t);
        } catch (NumberFormatException e) {
          throw new RuntimeException("Error building cache '" + vars.currentCacheModel.getId() + "' in '" + "resourceNAME" + "'.  Flush interval milliseconds must be a valid long integer value.  Cause: " + e, e);
        }
      }
    });
  }

  private void addParameterMapNodelets() {
    parser.addNodelet("/sqlMap/parameterMap/end()", new Nodelet() {
      public void process(Node node) throws Exception {

        vars.currentParameterMap.setParameterMappingList(vars.parameterMappingList);

        vars.client.getDelegate().addParameterMap(vars.currentParameterMap);

        vars.errorCtx.setMoreInfo(null);
        vars.errorCtx.setObjectId(null);
      }
    });
    parser.addNodelet("/sqlMap/parameterMap", new Nodelet() {
      public void process(Node node) throws Exception {
        vars.errorCtx.setActivity("building a parameter map");

        vars.currentParameterMap = new BasicParameterMap(vars.client.getDelegate());

        Properties attributes = NodeletUtils.parseAttributes(node, vars.properties);
        String id = applyNamespace(attributes.getProperty("id"));
        String parameterClassName = attributes.getProperty("class");
        parameterClassName = vars.typeHandlerFactory.resolveAlias(parameterClassName);

        vars.currentParameterMap.setId(id);
        vars.currentParameterMap.setResource(vars.errorCtx.getResource());

        vars.errorCtx.setObjectId(id + " parameter map");

        Class parameterClass = null;
        try {
          vars.errorCtx.setMoreInfo("Check the parameter class.");
          parameterClass = Resources.classForName(parameterClassName);
        } catch (Exception e) {
          //TODO: Why is this commented out?
          //throw new SqlMapException("Error configuring ParameterMap.  Could not set ParameterClass.  Cause: " + e, e);
        }

        vars.currentParameterMap.setParameterClass(parameterClass);

        vars.parameterMappingList = new ArrayList();

        vars.errorCtx.setMoreInfo("Check the parameter mappings.");
      }
    });
    parser.addNodelet("/sqlMap/parameterMap/parameter", new Nodelet() {
      public void process(Node node) throws Exception {
        Properties childAttributes = NodeletUtils.parseAttributes(node, vars.properties);
        String propertyName = childAttributes.getProperty("property");
        String jdbcType = childAttributes.getProperty("jdbcType");
        String type     = childAttributes.getProperty("typeName");
        String javaType = childAttributes.getProperty("javaType");
        String resultMap = childAttributes.getProperty("resultMap");
        String nullValue = childAttributes.getProperty("nullValue");
        String mode = childAttributes.getProperty("mode");
        String callback = childAttributes.getProperty("typeHandler");
        String numericScale = childAttributes.getProperty("numericScale");

        callback = vars.typeHandlerFactory.resolveAlias(callback);
        javaType = vars.typeHandlerFactory.resolveAlias(javaType);
        resultMap = applyNamespace( resultMap );

        vars.errorCtx.setObjectId(propertyName + " mapping of the " + vars.currentParameterMap.getId() + " parameter map");

        TypeHandler handler = null;
        if (callback != null) {
          vars.errorCtx.setMoreInfo("Check the parameter mapping typeHandler attribute '" + callback + "' (must be a TypeHandler or TypeHandlerCallback implementation).");
          try {
            Object impl = Resources.classForName(callback).newInstance();
            if (impl instanceof TypeHandlerCallback) {
              handler = new CustomTypeHandler((TypeHandlerCallback) impl);
            } else if (impl instanceof TypeHandler) {
              handler = (TypeHandler) impl;
            } else {
              throw new RuntimeException ("The class '"+callback+"' is not a valid implementation of TypeHandler or TypeHandlerCallback");
            }
          } catch (Exception e) {
            throw new RuntimeException("Error occurred during custom type handler configuration.  Cause: " + e, e);
          }
        } else {
          vars.errorCtx.setMoreInfo("Check the parameter mapping property type or name.");
          handler = resolveTypeHandler(vars.client.getDelegate().getTypeHandlerFactory(), vars.currentParameterMap.getParameterClass(), propertyName, javaType, jdbcType);
        }

        BasicParameterMapping mapping = new BasicParameterMapping();
        mapping.setPropertyName(propertyName);
        mapping.setJdbcTypeName(jdbcType);
        mapping.setTypeName(type);
        mapping.setResultMapName( resultMap );
        mapping.setNullValue(nullValue);
        if (mode != null && mode.length() > 0) {
          mapping.setMode(mode);
        }
        mapping.setTypeHandler(handler);
        try {
          if (javaType != null && javaType.length() > 0) {

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
91精品国产综合久久久蜜臀粉嫩| 成人黄色小视频在线观看| 欧美激情在线一区二区三区| 亚洲欧洲一区二区在线播放| 精品国免费一区二区三区| 日韩欧美www| 精品91自产拍在线观看一区| 精品成人a区在线观看| 精品国产污污免费网站入口 | 97久久精品人人澡人人爽| 国产91丝袜在线18| 暴力调教一区二区三区| 色婷婷综合久久| 欧美日韩mp4| 精品久久人人做人人爰| 日本一区二区综合亚洲| 亚洲视频在线观看一区| 亚洲一二三级电影| 免费观看一级欧美片| 国产一区二区免费视频| a美女胸又www黄视频久久| 色狠狠综合天天综合综合| 欧美少妇bbb| 久久丝袜美腿综合| 亚洲少妇最新在线视频| 色狠狠色噜噜噜综合网| 3d动漫精品啪啪一区二区竹菊| 欧美成人伊人久久综合网| 国产精品久久久久久一区二区三区| 亚洲伦理在线免费看| 日韩avvvv在线播放| 北条麻妃国产九九精品视频| 欧美伊人精品成人久久综合97| 欧美变态口味重另类| 亚洲日本在线看| 久久se这里有精品| 91精品办公室少妇高潮对白| 精品久久五月天| 亚洲永久免费av| 国产精品18久久久久久vr| 在线一区二区观看| 国产情人综合久久777777| 亚洲国产美女搞黄色| 国产激情视频一区二区三区欧美 | 波多野结衣中文一区| 欧美日本在线播放| 国产精品久久久一区麻豆最新章节| 午夜免费欧美电影| 99视频一区二区三区| 久久综合色之久久综合| 石原莉奈在线亚洲三区| 色一情一乱一乱一91av| 国产亚洲自拍一区| 蜜桃av一区二区在线观看 | 日韩欧美国产成人一区二区| 亚洲欧洲制服丝袜| 国产麻豆成人传媒免费观看| 91精品蜜臀在线一区尤物| 亚洲男同性视频| 波多野结衣的一区二区三区| 精品久久久久久亚洲综合网 | www.日韩精品| 日韩国产一区二| 欧美日韩精品一区视频| 亚洲一卡二卡三卡四卡| 91在线国产观看| 一区二区中文视频| 成人免费视频一区二区| 日本一区二区不卡视频| 国产电影精品久久禁18| 久久色成人在线| 黄色日韩网站视频| 26uuu亚洲婷婷狠狠天堂| 免费观看91视频大全| 欧美精品亚洲二区| 午夜精品久久久久久久久| 欧美日韩你懂得| 亚洲bt欧美bt精品| 日韩欧美一区中文| 免费日韩伦理电影| 欧美一级理论片| 九九**精品视频免费播放| 日韩三级伦理片妻子的秘密按摩| 日韩精品久久久久久| 欧美一级艳片视频免费观看| 日韩高清不卡一区二区| 欧美一区二区久久久| 国产在线精品一区二区三区不卡| 国产网站一区二区| 北岛玲一区二区三区四区| 亚洲人午夜精品天堂一二香蕉| 欧美亚洲丝袜传媒另类| 偷拍与自拍一区| 久久夜色精品国产噜噜av| 成人国产亚洲欧美成人综合网| 综合亚洲深深色噜噜狠狠网站| 在线亚洲精品福利网址导航| 国产精品一品二品| 亚洲欧美日韩国产成人精品影院| 欧美日韩性生活| 极品美女销魂一区二区三区免费| 国产精品久久久久久久久免费桃花| 欧美最猛黑人xxxxx猛交| 久久精品国产成人一区二区三区 | 国产精品白丝jk黑袜喷水| 亚洲视频香蕉人妖| 日韩一级片网站| 白白色 亚洲乱淫| 美女视频黄 久久| 亚洲欧美日韩久久精品| 精品乱人伦一区二区三区| 一本大道久久a久久综合婷婷| 美腿丝袜亚洲色图| 亚洲区小说区图片区qvod| 精品日韩一区二区三区 | 五月天久久比比资源色| 久久久久亚洲综合| 欧美日韩国产综合视频在线观看| 激情综合一区二区三区| 亚洲国产精品视频| 欧美精彩视频一区二区三区| 亚洲色图在线看| 亚洲精品一区二区三区在线观看| 欧美亚洲国产一区二区三区 | 婷婷综合另类小说色区| 欧美精彩视频一区二区三区| 欧美一区二区三区视频| 欧美性受xxxx黑人xyx性爽| 国产成人亚洲综合a∨猫咪| 日本大胆欧美人术艺术动态| 亚洲欧洲美洲综合色网| 久久久九九九九| 精品国产一区二区三区四区四| 7878成人国产在线观看| 色婷婷国产精品久久包臀| 成人免费毛片片v| 国产在线国偷精品产拍免费yy| 琪琪久久久久日韩精品| 亚洲一区二区在线免费观看视频| 亚洲欧美国产三级| 中文字幕一区二区日韩精品绯色| 欧美精品一区二区三区在线播放| 中文字幕日韩欧美一区二区三区| 欧美tk丨vk视频| 夜夜爽夜夜爽精品视频| 偷拍一区二区三区四区| 欧洲色大大久久| 亚洲精品国产品国语在线app| 欧美精彩视频一区二区三区| 26uuu色噜噜精品一区二区| 欧美精品亚洲二区| 91精品在线麻豆| 日韩精品专区在线影院重磅| 911国产精品| 9191久久久久久久久久久| 欧美疯狂性受xxxxx喷水图片| 欧美日韩高清影院| 欧美精品第1页| 日韩欧美的一区| 久久久蜜臀国产一区二区| 久久精品免视看| 国产精品国产三级国产三级人妇 | 亚洲一区二区精品视频| 亚洲视频免费在线观看| 洋洋av久久久久久久一区| 亚洲午夜影视影院在线观看| 亚洲h动漫在线| 黑人巨大精品欧美一区| 成人综合在线观看| 在线看不卡av| 91精品国产入口在线| 久久久av毛片精品| 国产精品久久久久久福利一牛影视| 亚洲美女少妇撒尿| 亚洲成a人v欧美综合天堂| 久久精品久久久精品美女| 国产91在线观看丝袜| 欧美亚洲尤物久久| 久久这里只有精品视频网| 国产精品情趣视频| 亚洲国产欧美在线| 国产一区二区三区在线看麻豆| 99精品桃花视频在线观看| 欧美精品第一页| 国产精品久久久久久久久免费樱桃 | 国产大片一区二区| 在线免费观看一区| 久久综合资源网| 一区二区三国产精华液| 久久不见久久见免费视频1| 成人高清伦理免费影院在线观看| 欧美喷潮久久久xxxxx| 亚洲综合色在线| 国内精品视频666| 欧美在线免费观看视频| 久久久久久免费| 亚洲成av人影院在线观看网| 国产成人在线观看免费网站| 678五月天丁香亚洲综合网| 国产精品久久久久7777按摩|