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

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

?? sqlmapconfigparser.java

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

import com.ibatis.common.resources.Resources;
import com.ibatis.common.xml.Nodelet;
import com.ibatis.common.xml.NodeletParser;
import com.ibatis.common.xml.NodeletUtils;

import com.ibatis.common.beans.ClassInfo;
import com.ibatis.sqlmap.client.SqlMapClient;
import com.ibatis.sqlmap.client.SqlMapException;
import com.ibatis.sqlmap.client.extensions.TypeHandlerCallback;
import com.ibatis.sqlmap.engine.accessplan.AccessPlanFactory;
import com.ibatis.sqlmap.engine.cache.CacheModel;
import com.ibatis.sqlmap.engine.cache.fifo.FifoCacheController;
import com.ibatis.sqlmap.engine.cache.lru.LruCacheController;
import com.ibatis.sqlmap.engine.cache.memory.MemoryCacheController;
import com.ibatis.sqlmap.engine.datasource.DataSourceFactory;
import com.ibatis.sqlmap.engine.datasource.DbcpDataSourceFactory;
import com.ibatis.sqlmap.engine.datasource.JndiDataSourceFactory;
import com.ibatis.sqlmap.engine.datasource.SimpleDataSourceFactory;
import com.ibatis.sqlmap.engine.impl.SqlMapClientImpl;
import com.ibatis.sqlmap.engine.impl.SqlMapExecutorDelegate;
import com.ibatis.sqlmap.engine.mapping.result.ResultObjectFactory;
import com.ibatis.sqlmap.engine.mapping.statement.MappedStatement;
import com.ibatis.sqlmap.engine.transaction.TransactionConfig;
import com.ibatis.sqlmap.engine.transaction.TransactionManager;
import com.ibatis.sqlmap.engine.transaction.external.ExternalTransactionConfig;
import com.ibatis.sqlmap.engine.transaction.jdbc.JdbcTransactionConfig;
import com.ibatis.sqlmap.engine.transaction.jta.JtaTransactionConfig;
import com.ibatis.sqlmap.engine.type.*;

import org.w3c.dom.Node;

import java.io.InputStream;
import java.io.Reader;
import java.util.Iterator;
import java.util.Properties;

public class SqlMapConfigParser extends BaseParser {

  protected final NodeletParser parser = new NodeletParser();
  private boolean usingStreams;

  public SqlMapConfigParser() {
    this(null, null);
  }

  public SqlMapConfigParser(XmlConverter sqlMapConfigConv, XmlConverter sqlMapConv) {
    super(new Variables());
    parser.setValidation(true);
    parser.setEntityResolver(new SqlMapClasspathEntityResolver());

    vars.sqlMapConfigConv = sqlMapConfigConv;
    vars.sqlMapConv = sqlMapConv;

    vars.delegate = new SqlMapExecutorDelegate();
    vars.typeHandlerFactory = vars.delegate.getTypeHandlerFactory();
    vars.client = new SqlMapClientImpl(vars.delegate);

    registerDefaultTypeAliases();

    addSqlMapConfigNodelets();
    addGlobalPropNodelets();
    addSettingsNodelets();
    addTypeAliasNodelets();
    addTypeHandlerNodelets();
    addTransactionManagerNodelets();
    addSqlMapNodelets();
    addResultObjectFactoryNodelets();

  }

  public SqlMapClient parse(Reader reader, Properties props) {
    vars.properties = props;
    return parse(reader);
  }

  public SqlMapClient parse(Reader reader) {
    try {
      if (vars.sqlMapConfigConv != null) {
        reader = vars.sqlMapConfigConv.convertXml(reader);
      }

      usingStreams = false;
      
      parser.parse(reader);
      return vars.client;
    } catch (Exception e) {
      throw new RuntimeException("Error occurred.  Cause: " + e, e);
    }
  }

  public SqlMapClient parse(InputStream inputStream, Properties props) {
    vars.properties = props;
    return parse(inputStream);
  }

  public SqlMapClient parse(InputStream inputStream) {
    try {
      if (vars.sqlMapConfigConv != null) {
        inputStream = vars.sqlMapConfigConv.convertXml(inputStream);
      }
      
      usingStreams = true;

      parser.parse(inputStream);
      return vars.client;
    } catch (Exception e) {
      throw new RuntimeException("Error occurred.  Cause: " + e, e);
    }
  }

  private void addSqlMapConfigNodelets() {
    parser.addNodelet("/sqlMapConfig/end()", new Nodelet() {
      public void process(Node node) throws Exception {
        Iterator cacheNames = vars.client.getDelegate().getCacheModelNames();

        while (cacheNames.hasNext()) {
          String cacheName = (String) cacheNames.next();
          CacheModel cacheModel = vars.client.getDelegate().getCacheModel(cacheName);
          Iterator statementNames = cacheModel.getFlushTriggerStatementNames();
          while (statementNames.hasNext()) {
            String statementName = (String) statementNames.next();
            MappedStatement statement = vars.client.getDelegate().getMappedStatement(statementName);
            if (statement != null) {
              statement.addExecuteListener(cacheModel);
            } else {
              throw new RuntimeException("Could not find statement named '" + statementName + "' for use as a flush trigger for the cache model named '" + cacheName + "'.");
            }
          }
        }
      }
    });
  }

  private void addGlobalPropNodelets() {
    parser.addNodelet("/sqlMapConfig/properties", new Nodelet() {
      public void process(Node node) throws Exception {
        vars.errorCtx.setActivity("loading global properties");

        Properties attributes = NodeletUtils.parseAttributes(node,vars.properties);
        String resource = attributes.getProperty("resource");
        String url = attributes.getProperty("url");

        try {
          Properties props = null;
          if (resource != null) {
            vars.errorCtx.setResource(resource);
            props = Resources.getResourceAsProperties(resource);
          } else if (url != null) {
            vars.errorCtx.setResource(url);
            props = Resources.getUrlAsProperties(url);
          } else {
            throw new RuntimeException("The " + "properties" + " element requires either a resource or a url attribute.");
          }

          if (vars.properties == null) {
            vars.properties = props;
          } else {
            props.putAll(vars.properties);
            vars.properties = props;
          }
        } catch (Exception e) {
          throw new RuntimeException("Error loading properties.  Cause: " + e);
        }
      }
    });
  }

  private void addSettingsNodelets() {
    parser.addNodelet("/sqlMapConfig/settings", new Nodelet() {
      public void process(Node node) throws Exception {
        vars.errorCtx.setActivity("loading settings properties");

        Properties attributes = NodeletUtils.parseAttributes(node, vars.properties);

        String classInfoCacheEnabledAttr = attributes.getProperty("classInfoCacheEnabled");
        boolean classInfoCacheEnabled = (classInfoCacheEnabledAttr == null || "true".equals(classInfoCacheEnabledAttr));
        ClassInfo.setCacheEnabled(classInfoCacheEnabled);

        String lazyLoadingEnabledAttr = attributes.getProperty("lazyLoadingEnabled");
        boolean lazyLoadingEnabled = (lazyLoadingEnabledAttr == null || "true".equals(lazyLoadingEnabledAttr));
        vars.client.getDelegate().setLazyLoadingEnabled(lazyLoadingEnabled);

        String statementCachingEnabledAttr = attributes.getProperty("statementCachingEnabled");
        boolean statementCachingEnabled = (statementCachingEnabledAttr == null || "true".equals(statementCachingEnabledAttr));
        vars.client.getDelegate().setStatementCacheEnabled(statementCachingEnabled);

        String cacheModelsEnabledAttr = attributes.getProperty("cacheModelsEnabled");
        boolean cacheModelsEnabled = (cacheModelsEnabledAttr == null || "true".equals(cacheModelsEnabledAttr));
        vars.client.getDelegate().setCacheModelsEnabled(cacheModelsEnabled);

        String enhancementEnabledAttr = attributes.getProperty("enhancementEnabled");
        boolean enhancementEnabled = (enhancementEnabledAttr == null || "true".equals(enhancementEnabledAttr));
        try {
          enhancementEnabled = enhancementEnabled && Resources.classForName("net.sf.cglib.proxy.InvocationHandler") != null;
        } catch (ClassNotFoundException e) {
          enhancementEnabled = false;
        }
        vars.client.getDelegate().setEnhancementEnabled(enhancementEnabled);

        String useStatementNamespacesAttr = attributes.getProperty("useStatementNamespaces");
        vars.useStatementNamespaces = ("true".equals(useStatementNamespacesAttr));

        String maxTransactions = attributes.getProperty("maxTransactions");
        if (maxTransactions != null && Integer.parseInt(maxTransactions) > 0) {
          vars.client.getDelegate().setMaxTransactions(Integer.parseInt(maxTransactions));
        }

        String maxRequests = attributes.getProperty("maxRequests");
        if (maxRequests != null && Integer.parseInt(maxRequests) > 0) {
          vars.client.getDelegate().setMaxRequests(Integer.parseInt(maxRequests));
        }

        String maxSessions = attributes.getProperty("maxSessions");
        if (maxSessions != null && Integer.parseInt(maxSessions) > 0) {
          vars.client.getDelegate().setMaxSessions(Integer.parseInt(maxSessions));
        }

        AccessPlanFactory.setBytecodeEnhancementEnabled(vars.client.getDelegate().isEnhancementEnabled());
        
        String defaultStatementTimeout = attributes.getProperty("defaultStatementTimeout");
        if (defaultStatementTimeout != null) {
          try {
            Integer defaultTimeout = Integer.valueOf(defaultStatementTimeout);
            vars.defaultStatementTimeout = defaultTimeout;
          } catch (NumberFormatException e) {
            throw new SqlMapException("Specified defaultStatementTimeout is not a valid integer");
          }
        }
      }
    });
  }

  private void addTypeAliasNodelets() {

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产一区二区三区高清播放| 欧美bbbbb| 欧美精品一区二区三区蜜臀| 4hu四虎永久在线影院成人| 欧美视频中文字幕| 欧美在线观看一区二区| 日本高清无吗v一区| 91麻豆免费看片| 色综合久久久久综合| 91麻豆国产在线观看| 91成人在线免费观看| 欧美日韩一区中文字幕| 日韩欧美专区在线| 国产亚洲人成网站| 亚洲欧美视频在线观看| 亚洲一区在线免费观看| 亚洲综合成人在线| 麻豆成人久久精品二区三区小说| 国产在线精品一区二区夜色 | 精品欧美黑人一区二区三区| 26uuu成人网一区二区三区| 国产调教视频一区| 亚洲综合免费观看高清在线观看| 蜜臀av性久久久久蜜臀aⅴ四虎 | 26uuu久久天堂性欧美| 亚洲国产精品成人综合色在线婷婷| 1024成人网| 日韩av不卡在线观看| 成人激情视频网站| 欧美性一区二区| 久久亚洲精华国产精华液| **欧美大码日韩| 日韩高清不卡在线| 成人在线一区二区三区| 欧美三级一区二区| 久久蜜臀精品av| 午夜av区久久| 成人国产免费视频| 777欧美精品| 国产精品国产a| 美女在线视频一区| 在线免费亚洲电影| 久久色在线观看| 日韩综合在线视频| av电影天堂一区二区在线| 日韩精品一区二区三区视频| 亚洲一级电影视频| av在线播放成人| 国产午夜精品福利| 日本欧洲一区二区| 欧美在线视频全部完| 国产精品毛片大码女人| 韩国一区二区视频| 在线播放日韩导航| 一区二区成人在线| 91亚洲精品久久久蜜桃网站 | 欧美三区免费完整视频在线观看| 国产欧美日韩卡一| 九九精品一区二区| 在线不卡的av| 亚洲aaa精品| 日本道色综合久久| 中文字幕亚洲视频| 国产精品一区二区x88av| 欧美成人一区二区| 蜜桃视频一区二区| 欧美成人性福生活免费看| 丝袜亚洲另类丝袜在线| 欧美年轻男男videosbes| 亚洲一区在线观看免费 | 麻豆免费看一区二区三区| 欧美欧美欧美欧美| 亚洲mv在线观看| 欧美精品第一页| 久热成人在线视频| 欧美成人午夜电影| 激情另类小说区图片区视频区| 日韩手机在线导航| 韩国精品久久久| 久久久99精品久久| caoporm超碰国产精品| 亚洲欧美在线高清| 色呦呦网站一区| 亚洲国产精品影院| 日韩一区二区三区视频在线| 韩日精品视频一区| 国产精品美女视频| 日本乱人伦aⅴ精品| 午夜精品免费在线| 日韩欧美在线123| 国产麻豆一精品一av一免费| 中文字幕在线观看一区二区| 色网站国产精品| 亚洲777理论| 久久精品在这里| 色综合久久中文字幕| 青青草原综合久久大伊人精品优势| 日韩欧美中文一区二区| 福利一区二区在线观看| 亚洲三级小视频| 欧美成人精精品一区二区频| 风间由美一区二区av101| 亚洲一区免费视频| 精品福利一二区| 一本大道久久a久久精品综合| 日韩一区欧美二区| 中文字幕的久久| 欧美精品日韩一本| 成人午夜短视频| 肉肉av福利一精品导航| 国产精品久久看| 制服丝袜国产精品| 99久久免费精品| 麻豆91在线看| 一区二区三区精密机械公司| 日韩欧美一级片| 在线观看欧美日本| 丁香啪啪综合成人亚洲小说| 午夜久久久影院| 中文字幕在线一区二区三区| 欧美一级一级性生活免费录像| 成人精品视频一区二区三区尤物| 亚洲超碰97人人做人人爱| 中文一区二区在线观看| 欧美成人艳星乳罩| 欧美揉bbbbb揉bbbbb| 成人免费看视频| 狠狠色丁香婷婷综合| 五月婷婷久久综合| 亚洲精品少妇30p| 久久精品亚洲精品国产欧美kt∨| 91精品婷婷国产综合久久| av电影一区二区| 成人免费视频一区二区| 精品午夜一区二区三区在线观看| 亚洲成人资源网| 亚洲综合在线电影| 国产精品二区一区二区aⅴ污介绍| 久久亚洲综合av| 精品国产乱码久久久久久牛牛| 91麻豆精品国产91久久久久久| 在线观看精品一区| 欧美综合欧美视频| 色偷偷成人一区二区三区91| 成人av在线资源| www.欧美亚洲| 成人丝袜18视频在线观看| 国产精品白丝jk黑袜喷水| 国产一区二区精品久久| 国产综合色精品一区二区三区| 久久69国产一区二区蜜臀| 日本91福利区| 精品一二线国产| 国模一区二区三区白浆| 国产一区二区三区在线观看免费视频| 亚洲午夜在线观看视频在线| 一区二区在线看| 亚洲国产综合人成综合网站| 亚洲国产一区二区三区| 午夜免费欧美电影| 丝袜诱惑制服诱惑色一区在线观看| 日韩电影网1区2区| 麻豆成人久久精品二区三区红 | 精品日韩av一区二区| 日韩欧美成人一区| 2021国产精品久久精品| 国产欧美日韩不卡| 亚洲婷婷国产精品电影人久久| 亚洲免费在线观看视频| 亚洲中国最大av网站| 丝袜美腿亚洲色图| 国产一区二区毛片| 一本色道久久综合狠狠躁的推荐| 在线视频亚洲一区| 欧美不卡一区二区三区| 国产精品美女久久久久久2018| 国产精品国产三级国产aⅴ无密码| 夜夜揉揉日日人人青青一国产精品| 五月天一区二区三区| 极品少妇一区二区| 91亚洲国产成人精品一区二区三| 欧洲一区二区三区在线| 久久一区二区三区四区| 亚洲天堂a在线| 精品无人区卡一卡二卡三乱码免费卡| 国产一区91精品张津瑜| 色综合天天狠狠| 日韩视频在线永久播放| 最新热久久免费视频| 日韩中文字幕一区二区三区| 国产成人精品亚洲777人妖| 91色视频在线| 精品国产一区二区在线观看| 亚洲欧美二区三区| 激情综合色播激情啊| 色94色欧美sute亚洲13| 久久精品免费在线观看| 亚洲 欧美综合在线网络| 成人国产精品免费观看动漫| 日韩亚洲电影在线|