properties
這些是外部化的,可替代的屬性,這些屬性也可以配置在典型的Java屬性配置文件中,或者通過properties元素的子元素來傳遞。例如:
<properties resource="org/mybatis/example/config.properties"> <property name="username" value="dev_user"/> <property name="password" value="F2Fa3!33TYyg"/> </properties>
其中的屬性就可以在整個配置文件中使用,使用可替換的屬性來實現動態配置。比如:
<dataSource type="POOLED"> <property name="driver" value="${driver}"/> <property name="url" value="${url}"/> <property name="username" value="${username}"/> <property name="password" value="${password}"/> </dataSource>
這個例子中的username和password將會由properties元素中設置的值來替換。 driver和url屬性將會從包含進來的config.properties文件中的值來替換。
Settings
1.cacheEnabled
這個配置使全局的映射器啟用或禁用緩存。
有效值:true,false
默認值:true
2.lazyLoadingEnabled
全局啟用或禁用延遲加載。當禁用時,所有關聯對像都會即時加載。
有效值:true,false
默認值:true
3.aggressiveLazyLoading
當啟用時,有延遲加載屬性的對像在被調用時將會完全加載任意屬性。否則,
每種屬性將會按需要加載。
有效值:true,false
默認值:true
4.mult ipleResultSetsEnabled
允許或不允許多種結果集從一個單獨的語句中返回(需要適合的驅動)
有效值:true,false
默認值:true
5.useColumnLabel
使用列標籤代替列名。不同的驅動在這方便表現不同。參考驅動文檔或充分測試兩種方法來決定所使用的驅動。
有效值:true,false
默認值:true
6.useGeneratedKeys
允許JDBC支持生成的鍵。需要適合的驅動。如果設置為true則這個設置強制生成的鍵被使用,儘管一些驅動拒絕兼容但仍然有效(比如Derby)
有效值:true,false
默認值:false
7.autoMappingBehavior
指定MyBatis如何自動映射列到字段/屬性。 PARTIAL只會自動映射簡單,沒有嵌套的結果。
FULL會自動映射任意複雜的結果(嵌套的或其他情況)
有效值:NONE,PARTIAL,FULL
默認值:PARTIAL
8.defaultExecutorType
配置默認的執行器。 SIMPLE 執行器沒有什麼特別之處。 REUSE執行器重用預處理語句。
BATCH 執行器重用語句和批量更新有效值:SIMPLE,REUSE,BATCH
默認值:SIMPLE
9.defaultStatementTimeout
設置超時時間,它決定驅動等待一個數據庫響應的時間。
有效值:Any,positive,integer
默認值:Not Set(null)
一個設置信息元素的示例,完全的配置如下所示:
<settings> <setting name="cacheEnabled" value="true"/> <setting name="lazyLoadingEnabled" value="true"/> <setting name="multipleResultSetsEnabled" value="true"/> <setting name="useColumnLabel" value="true"/> <setting name="useGeneratedKeys" value="false"/> <setting name="enhancementEnabled" value="false"/> <setting name="defaultExecutorType" value="SIMPLE"/> <setting name="defaultStatementTimeout" value="25000"/> </settings>
typeAliases
類型別名是為Java類型命名一個短的名字。它只和XML配置有關,只用來減少類完全限定名的多餘部分。例如:
<typeAliases> <typeAlias alias="Author" type="domain.blog.Author"/> <typeAlias alias="Blog" type="domain.blog.Blog"/> <typeAlias alias="Comment" type="domain.blog.Comment"/> <typeAlias alias="Post" type="domain.blog.Post"/> <typeAlias alias="Section" type="domain.blog.Section"/> <typeAlias alias="Tag" type="domain.blog.Tag"/> </typeAliases>
使用這個配置,“Blog”可以任意用來替代“domain.blog.Blog”所使用的地方。 對於普通的Java 類型,有許多內建的類型別名。它們都是大小寫不敏感的,由於重載的名字,要注意原生類型的特殊處理。
typeHandlers
無論是MyBatis在預處理語句中設置一個參數,還是從結果集中取出一個值時,類型處理器被用來將獲取的值以合適的方式轉換成Java類型。下面這個表格描述了默認的類型處理器。
你可以重寫類型處理器或創建你自己的類型處理器來處理不支持的或非標準的類型。但這種情況相當少! !
objectFactory
MyBatis每次創建結果對像新的實例時,它使用一個ObjectFactory實例來完成。如果參數映射存在,默認的ObjectFactory不比使用默認構造方法或帶參數的構造方法實例化目標類做的工作多。如果你想重寫默認的ObjectFactory,你可以創建你自己的。實例略。
plugins
MyBatis允許你在某一點攔截已映射語句執行的調用。默認情況下,MyBatis允許使用插件來攔截方法調用:
1.Executor
(update, query, flushStatements, commit, rollback, getTransaction, close, isClosed)
2.ParameterHandler
(getParameterObject, setParameters)
3.ResultSetHandler
(handleResultSets, handleOutputParameters)
4.StatementHandler
(prepare, parameterize, batch, update, query)
environments
MyBatis可以配置多種環境。這會幫助你將SQL映射應用於多種數據庫之中。
一個很重要的問題要記得:你可以配置多種環境,但你只能為每個SqlSessionFactory實例選擇一個。所以,如果你想連接兩個數據庫,你需要創建兩個SqlSessionFactory實例,每個數據庫對應一個。而如果是三個數據庫,你就需要三個實例,以此類推。
環境元素定義瞭如何配置環境,如例:
<environments default="development"> <environment id="development"> <transactionManager type="JDBC"> <property name="..." value="..."/> </transactionManager> <dataSource type="POOLED"> <property name="driver" value="${driver}"/> <property name="url" value="${url}"/> <property name="username" value="${username}"/> <property name="password" value="${password}"/> </dataSource> </environment> </environments>注意這裡:
1.默認的環境ID(比如:default=”development”)。
2.每個environment 元素定義的環境ID(比如:id=”development”)。
3.事務管理器的配置(比如:type=”JDBC”)。
4.數據源的配置(比如:type=”POOLED”)。
transactionManager
在MyBatis中有兩種事務管理器類型(也就是type="[JDBC|MANAGED]"。
1.JDBC---這個配置直接簡單使用了JDBC的提交和回滾設置。它依賴於從數據源得到的連接來管理事務範圍。
2.MANAGED---這個配置幾乎沒做什麼。它從來不提交或回滾一個連接。而它會讓容器來管理事務的整個生命週期(比如Spring或JEE應用服務器的上下文)。默認情況下它會關閉連接。然而一些容器並不希望這樣,因此如果你需要從連接中停止它,將closeConnection屬性設置為false。例如:
<transactionManager type="MANAGED"> <property name="closeConnection" value="false"/> </transactionManager>
這兩種事務管理器都不需要任何屬性。然而它們都是類型別名,要替換它們,你需要放置你自己的類的完全限定名或類型別名,它們引用了你對TransacFactory接口的實現類。