亚洲欧美第一页_禁久久精品乱码_粉嫩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一区二区三区免费野_久草精品视频
一区二区视频在线看| 亚洲一区精品在线| 视频在线观看一区| 91精品在线一区二区| 亚洲成人在线网站| 日韩情涩欧美日韩视频| 久久国产福利国产秒拍| 久久这里只有精品6| 成人av中文字幕| 亚洲精品国产品国语在线app| 日本一区二区三区四区在线视频| 日本韩国欧美一区二区三区| 奇米精品一区二区三区在线观看一 | 26uuu另类欧美| 欧美一区二区三区不卡| 成人av资源在线观看| 99免费精品在线观看| 亚洲高清免费观看| 国产精品污网站| 制服丝袜亚洲色图| wwwwxxxxx欧美| 日本一区二区三区国色天香| 国产精品福利一区二区三区| 91精品国产色综合久久ai换脸 | 高清国产一区二区| 婷婷开心久久网| 亚洲欧美另类久久久精品2019| 欧美成人精品高清在线播放| 在线观看亚洲精品| 成人精品鲁一区一区二区| 一区二区三区四区高清精品免费观看 | 成人精品亚洲人成在线| 韩国av一区二区三区在线观看| 欧美国产日韩在线观看| 欧美肥妇毛茸茸| 岛国一区二区三区| 欧美图片一区二区三区| av资源网一区| 在线综合亚洲欧美在线视频| 精品国一区二区三区| 91精品国产综合久久久久久久久久 | 色综合久久精品| 国产成人精品一区二| 麻豆精品一区二区三区| 亚洲国产精品久久久久秋霞影院| 日本成人中文字幕| 懂色av一区二区三区免费看| 北条麻妃国产九九精品视频| 欧美一区二区在线免费播放| 国产精品短视频| 美洲天堂一区二卡三卡四卡视频 | 亚洲一区二区三区视频在线播放| 久久99国产精品免费| 日本vs亚洲vs韩国一区三区| 成人毛片在线观看| 日韩欧美一级特黄在线播放| 欧美日韩一本到| 欧美日韩一区精品| 国产精品成人一区二区艾草| 老鸭窝一区二区久久精品| 欧美视频一区在线观看| 中文字幕一区二区三区视频| 亚洲天堂久久久久久久| 亚洲一区精品在线| 色综合天天狠狠| 中文字幕一区二区三区乱码在线| 国产在线不卡一卡二卡三卡四卡| 激情综合色播五月| 欧美群妇大交群中文字幕| 日韩欧美精品在线| 日韩专区欧美专区| 欧美亚洲综合在线| 亚洲一区二区在线观看视频| 99精品视频一区二区三区| 欧美亚洲一区二区在线| 亚洲精选视频在线| 色诱视频网站一区| 亚洲日本在线看| 色综合网色综合| 制服视频三区第一页精品| 亚洲一区二区三区在线播放| 色系网站成人免费| 国产一区二区精品久久91| 精品国产电影一区二区| 精品在线观看视频| 精品99一区二区三区| 国产精品12区| 国产精品三级av| 99国产精品国产精品久久| 亚洲精品乱码久久久久久黑人| 91丨国产丨九色丨pron| 欧美日韩黄视频| 麻豆传媒一区二区三区| 国产日韩欧美激情| 99精品久久久久久| 一区二区三区高清不卡| 337p亚洲精品色噜噜| 久色婷婷小香蕉久久| 日本一区二区免费在线| 91美女片黄在线观看| 亚洲天堂av一区| 欧美一区二区三区系列电影| 裸体在线国模精品偷拍| 国产精品免费人成网站| 欧美日韩综合色| 久久se精品一区精品二区| 久久一区二区视频| 91视频国产观看| 蜜桃视频在线观看一区| 日本一区二区三区四区| 欧美日韩中文字幕精品| 国产美女主播视频一区| 国产精品久久综合| 国产精品人妖ts系列视频| 在线中文字幕一区二区| 韩国欧美国产一区| 亚洲精品日产精品乱码不卡| 日韩欧美国产高清| 99久久久久久| 国产在线国偷精品免费看| 亚洲影院久久精品| 久久久精品国产免大香伊| 日韩精品1区2区3区| 国产精品久久久久久久久免费丝袜| 99国产精品久久久久久久久久| 日韩av一二三| 亚洲免费观看在线观看| 久久伊人蜜桃av一区二区| 欧美色国产精品| 成人免费视频免费观看| 免费av成人在线| 亚洲bt欧美bt精品| 亚洲美腿欧美偷拍| 国产欧美视频一区二区三区| 欧美一区二区在线视频| 欧美视频一区二区三区| 成人99免费视频| 久久91精品国产91久久小草| 午夜久久福利影院| 亚洲精品欧美激情| 国产精品久久久久aaaa| 久久一区二区三区四区| 欧美不卡在线视频| 91精品在线免费| 欧美精品在欧美一区二区少妇| 色综合久久天天综合网| 99久久免费精品高清特色大片| 国产精品一区二区久久精品爱涩 | 国产精品丝袜久久久久久app| 日韩三级电影网址| 日韩精品一区二区三区在线| 91精品福利在线一区二区三区 | 亚洲午夜一区二区三区| 亚洲精品免费看| 亚洲国产毛片aaaaa无费看| 一区二区成人在线视频| 亚洲同性gay激情无套| 亚洲欧美在线视频观看| 亚洲黄一区二区三区| 亚洲一二三四在线观看| 性久久久久久久久| 丝袜诱惑制服诱惑色一区在线观看| 亚洲国产成人va在线观看天堂| 亚洲丶国产丶欧美一区二区三区| 亚洲一区二区三区美女| 五月天激情综合网| 久久99这里只有精品| 国产一区二区在线看| 国产.欧美.日韩| 色天天综合色天天久久| 777a∨成人精品桃花网| 精品成人佐山爱一区二区| 国产日韩精品一区二区浪潮av| 国产欧美日韩久久| 亚洲综合色视频| 久久er99热精品一区二区| 豆国产96在线|亚洲| 欧美日韩一区二区三区四区五区| 91精品福利在线一区二区三区| 国产亚洲欧洲一区高清在线观看| 欧美专区日韩专区| 日韩美女主播在线视频一区二区三区| 精品国产一区二区三区四区四| 国产欧美精品国产国产专区| 亚洲免费毛片网站| 国产在线一区观看| 一本到一区二区三区| 精品美女一区二区三区| 亚洲人123区| 蜜臀国产一区二区三区在线播放| 国产91丝袜在线18| 欧美日韩免费观看一区三区| 久久久久久久久久久黄色 | 成人国产免费视频| 亚洲欧美日韩一区二区三区在线观看 | 韩国一区二区视频| 91色视频在线| 日韩一区二区三区视频在线观看| 亚洲男同1069视频| jizzjizzjizz欧美|