zoukankan      html  css  js  c++  java
  • iBATIS sqlMapConfig配置详解

      1 <?xml version="1.0" encoding="UTF-8" ?>
      2 <!DOCTYPE sqlMapConfig 
      3 PUBLIC "-//ibatis.apache.org//DTD SQL Map Config 2.0//EN" 
      4 "http://ibatis.apache.org/dtd/sql-map-config-2.dtd">
      5 <sqlMapConfig>
      6 <!-- 
      7 <properties resource="properties/database.properties"/>
      8 可将SqlMap中的<property />内容写到配置文件中,从此处引用。
      9 SQL Map配置文件及其每个映射文件都可以使用占位符${}
     10 -->
     11 <settings 
     12 cacheModelsEnabled="true" 
     13 enhancementEnabled="true" 
     14 lazyLoadingEnabled="true" 
     15 errorTracingEnabled="true" 
     16 maxRequests="32" 
     17 maxSessions="10" 
     18 maxTransactions="5" 
     19 useStatementNamespaces="false" 
     20 />
     21 <!-- 
     22 <settings 
     23 cacheModelsEnabled="true" 
     24 是否启用SqlMapClient上的缓存机制。 
     25 建议设为"true" 
     26 enhancementEnabled="true" 
     27 是否针对POJO启用字节码增强机制以提升
     28 getter/setter的调用效能,避免使用Java 
     29 Reflect所带来的性能开销。 
     30 同时,这也为Lazy Loading带来了极大的性能
     31 提升。 
     32 建议设为"true" 
     33 lazyLoadingEnabled="true" 
     34 是否启用延迟加载机制,建议设为"true" 
     35 errorTracingEnabled="true" 
     36 是否启用错误日志,在开发期间建议设为"true"
     37 以方便调试 
     38 maxRequests="32" 
     39 最大并发请求数(Statement并发数) 
     40 maxSessions="10" 
     41 最大Session数。即当前最大允许的并发
     42 SqlMapClient 数。 
     43 maxSessions设定必须介于
     44 maxTransactions和maxRequests之间,即 
     45 maxTransactions<maxSessions=<maxRequests 
     46 maxTransactions="5" 
     47 最大并发事务数 
     48 useStatementNamespaces="false" 
     49 是否使用Statement命名空间。 
     50 这里的命名空间指的是映射文件中, sqlMap节点
     51 的namespace属性,如在上例中针对t_user
     52 表的映射文件sqlMap节点: 
     53 <sqlMap namespace="User"> 
     54 这里,指定了此sqlMap节点下定义的操作均从
     55 属于"User"命名空间。 
     56 在useStatementNamespaces="true"的情
     57 况下,Statement调用需追加命名空间,如:
     58 sqlMap.update("User.updateUser",user); 
     59 否则直接通过Statement名称调用即可,如: 
     60 sqlMap.update("updateUser",user); 
     61 但请注意此时需要保证所有映射文件中,
     62 Statement定义无重名。 
     63 />
     64 -->
     65 
     66 <transactionManager type="JDBC" commitRequired="false">
     67 
     68 <!--
     69 <transationManager>元素让您为SQL Map配置事务管理服务。
     70 属性type指定所使用的事务管理器类型。
     71 这个属性值可以是一个类名,也可以是一个别名。
     72 包含在框架的三个事务管理器分别是:JDBC,JTA和EXTERNAL。
     73 
     74 JDBC:通过常用的Connection commit()和rollback()方法,让JDBC管理事务。
     75 
     76 JTA:本事务管理器使用一个JTA全局事务,使SQL Map的事务包括在更大的事务范围内,
     77 这个更大的事务范围可能包括了其他的数据库和事务资源。
     78 这个配置需要一个UserTransaction属性,以便从JNDI获得一个UserTransaction。
     79 
     80 EXTERNAL:这个配置可以让您自己管理事务。您仍然可以配置一个数据源,
     81 但事务不再作为框架生命周期的一部分被提交或回退。
     82 这意味着SQL Map外部应用的一部分必须自己管理事务。
     83 这个配置也可以用于没有事务管理的数据库(例如只读数据库)。
     84 -->
     85 
     86 <dataSource type="DBCP">
     87 <!-- 
     88 <datasource>是<transactionManager>的一部分,
     89 为SQL Map数据源设置了一系列参数。
     90 目前SQL Map架构只提供三个DataSource Factory,但您也可以添加自己的实现。
     91 
     92 SIMPLE: SimpleDataSourceFactory为DataSource提供了一个基本的实现,
     93 适用于在没有J2EE容器提供DataSource的情况。
     94 它基于iBatis的SimpleDataSource连接池实现。 
     95 
     96 DBCP: DbcpDataSourceFactory实现使用Jakarta DBCP
     97 (Database Connection Pool)的DataSource API提供连接池服务。
     98 适用于应用/Web容器不提供DataSource服务的情况,或执行一个单独的应用。
     99 
    100 JNDI: JndiDataSourceFactory在应用容器内部从JNDI Context中
    101 查找DataSource实现。当使用应用服务器,并且服务器提供了容器管理的连
    102 接池和相关DataSource实现的情况下,可以使用JndiDataSourceFactory。
    103 使用JDBC DataSource的标准方法是通过JNDI来查找。
    104 -->
    105 
    106 <property name="JDBC.Driver" 
    107 value="net.sourceforge.jtds.jdbc.Driver"/>
    108 <property name="JDBC.ConnectionURL" 
    109 value="jdbc:jtds:sqlserver://127.0.0.1:1433/EXTFFM"/>
    110 <property name="JDBC.Username" value="sa"/>
    111 <property name="JDBC.Password" value="sa"/>
    112 <!--
    113 SQL Map配置文件拥有唯一的<properties>元素,
    114 用于在配置文件中使用标准的Java属性文件(name=value)。
    115 这样做后,在属性文件中定义的属性可以作为变量在SQL Map配置文件
    116 及其包含的所有SQL Map映射文件中引用。
    117 
    118 例如,如果属性文件中包含属性:
    119 driver=org.hsqldb.jdbcDriver
    120 SQL Map配置文件及其每个映射文件都可以使用占位符${driver}
    121 来代表值org.hsqldb.jdbcDriver。例如:
    122 <property name="JDBC.Driver" value="${driver}"/>
    123 -->
    124 
    125 <property name="Pool.MaximumActiveConnections" value="10"/>
    126 <!-- 数据库连接池可维持的最大容量。缺省值: 10 -->
    127 
    128 <property name="Pool.MaximumIdleConnections" value="5"/>
    129 <!-- 数据库连接池中允许的挂起(idle)连接数。缺省值: 5 -->
    130 
    131 <property name="Pool.TimeToWait" value="500" />
    132 <!-- 
    133 当线程试图从连接池中获取连接时,连接池中无可用连接可供使用,
    134 此时线程将进入等待状态,直到池中出现空闲连接。
    135 此参数设定了线程所允许等待的最长时间(单位:毫秒)缺省值: 10 
    136 -->
    137 <property name="Pool.MaximumCheckoutTime" value="120000"/>
    138 
    139 <!-- 
    140 数据库联接池中,连接被某个任务所允许占用的最大时间,
    141 如果超过这个时间限定,连接将被强制收回(单位:毫秒)。
    142 缺省值: 20000 
    143 -->
    144 
    145 
    146 <property name="Pool.PingQuery" value="seslct 1 from FFM_Sequence" />
    147 <!--
    148 数据库连接状态检测语句。
    149 某些数据库在连接在某段时间持续处于空闲状态时会将其断开。
    150 而连接池管理器将通过此语句检测池中连接是否可用。
    151 它对性能的影响较大,应小心使用。检测语句应该是一个最简化的无逻辑SQL,
    152 如:select 1 from dual缺省值: N/A
    153 --> 
    154 
    155 <property name="Pool.PingEnabled" value="false" />
    156 <!-- 是否允许检测连接状态。缺省值: false -->
    157 
    158 <property name="Pool.PingConnectionsOlderThan" value="1" />
    159 <!-- 对持续连接时间超过设定值(毫秒)的连接进行检测。缺省值: 0 -->
    160 
    161 <property name="Pool.PingConnectionsNotUsedFor" value="1" />
    162 <!-- 对空闲超过设定值(毫秒)的连接进行检测。缺省值: 0 -->
    163 </dataSource>
    164 </transactionManager>
    165 <sqlMap resource="com/witnessj/ffm/domain/IBatisSqlMap/SequenceSqlMap.xml"/>
    166 <!--
    167 <sqlMap>元素用于包括SQL Map映射文件和其他的SQL Map配置文件。
    168 每个SqlMapClient对象使用的所有SQL Map映射文件都要在此声明。
    169 映射文件作为stream resource从类路径或URL读入。
    170 您必须在这里指定所有的SQL Map文件。
    171 
    172 List more here...
    173 <sqlMap resource="com/mydomain/data/Order.xml"/>
    174 <sqlMap resource="com/mydomain/data/Documents.xml"/>
    175 -->
    176 </sqlMapConfig>
  • 相关阅读:
    mysql--对行(表中数据)的增删改查
    mysql--MySQL数据库的简单认识
    mysql--mysql的安装与目录介绍
    mysql--数据库的简单认识
    mysql--对库,表基本操作语句,增删改查
    python网络编程--协程
    python网络编程--线程的方法,线程池
    python网络编程--线程(锁,GIL锁,守护线程)
    python网络编程--管道,信号量,Event,进程池,回调函数
    python网络编程--进程(方法和通信),锁, 队列,生产者消费者模型
  • 原文地址:https://www.cnblogs.com/lcngu/p/5083712.html
Copyright © 2011-2022 走看看