摘要:一配置屬性詳解可以在各式各樣不同環境下工作而設計的因此存在著大量的配置參數。以簡便操作,多數配置參數都有默認的配置值也是我們日常使用的必須品。
Hibernate (開放源代碼的對象關系映射框架)
Hibernate是一個開放源代碼的對象關系映射框架,它對JDBC進行了非常輕量級的對象封裝, 它將POJO與數據庫表建立映射關系,是一個全自動的orm框架,hibernate可以自動生成SQL 語句,自動執行,使得Java程序員可以隨心所欲的使用對象編程思維來操縱數據庫。 Hibernate可以應用在任何使用JDBC的場合,既可以在Java的客戶端程序使用,也 可以在Servlet/JSP的Web應用中使用,最具革命意義的是,Hibernate可以在應用 EJB的J2EE架構中取代CMP,完成數據持久化的重任。一.hibernate配置屬性詳解
hibbernate可以在各式各樣不同環境下工作而設計的, 因此存在著大量的配置參數。以簡便操 作,多數配置參數都有默認的配置值,也是我們日常使用hibernate的必須品。Hibernate JDBC屬性
----------------------------------------------------------------------------------- | 屬性名 | 用途 ----------------------------------------------------------------------------------- | hibernate.connection.driver_class | jdbc驅動類 | hibernate.connection.url | jdbc URL | hibernate.connection.username | 數據庫用戶 | hibernate.connection.password | 數據庫用戶密碼 | hibernate.connection.pool_size | 連接池容量上限數目 -----------------------------------------------------------------------------------Hibernate 數據源屬性
----------------------------------------------------------------------------------- |屬性名 | 用途 ----------------------------------------------------------------------------------- |hibernate.connection.datasource | 數據源JNDI名字 |hibernate.jndi.url | DI提供者的URL (可選) |hibernate.jndi.class | DI InitialContextFactory類 (可選) |hibernate.connection.username | 數據庫用戶 (可選) |hibernate.connection.password | 數據庫用戶密碼 (可選) -----------------------------------------------------------------------------------可選的配置屬性
----------------------------------------------------------------------------------- |屬性名 | 用途 ---------------------------------------------------------------------------------------------------------------------------------------------------------------- hibernate.dialect | 一個Hibernate Dialect類名允許Hibernate針對特定的關系數據庫生成優化的SQL.取值 full.classname.of.Dialect hibernate.show_sql | 輸出所有SQL語句到控制臺. 有一個另外的選擇是把org.hibernate.SQL這個log category設為debug。eg. true | false hibernate.format_sql | 在log和console中打印出更漂亮的SQL。取值 true | false hibernate.default_schema | 在生成的SQL中, 將給定的schema/tablespace附加于非全限定名的表名上.取值 SCHEMA_NAME hibernate.default_catalog | 在生成的SQL中, 將給定的catalog附加于非全限定名的表名上.取值 CATALOG_NAME hibernate.session_factory_name | SessionFactory創建后,將自動使用這個名字綁定到JNDI中.取值 jndi/composite/name hibernate.max_fetch_depth | 為單向關聯(一對一, 多對一)的外連接抓取(outer join fetch)樹設置最大深度. 值為0意味著將關閉默認的外連接抓取.取值 建議在0到3之間取值 hibernate.default_batch_fetch_size | 為Hibernate關聯的批量抓取設置默認數量.取值 建議的取值為4, 8, 和16 hibernate.default_entity_mode | 為由這個SessionFactory打開的所有Session指定默認的實體表現模式.取值 dynamic-map, dom4j, pojo hibernate.order_updates | 強制Hibernate按照被更新數據的主鍵,為SQL更新排序。這么做將減少在高并發系統中事務的死鎖。取值 true | false hibernate.generate_statistics | 如果開啟, Hibernate將收集有助于性能調節的統計數據.取值 true | false hibernate.use_identifer_rollback | 如果開啟, 在對象被刪除時生成的標識屬性將被重設為默認值.取值 true | false hibernate.use_sql_comments | 如果開啟, Hibernate將在SQL中生成有助于調試的注釋信息, 默認值為false.取值 true | false ----------------------------------------------------------------------------------------------------------------------------------------------------------------Hibernate JDBC和連接(connection)屬性:
---------------------------------------------------------------------------------------------------------------------------------------------------------------------- 屬性名 | 用途 ---------------------------------------------------------------------------------------------------------------------------------------------------------------------- hibernate.jdbc.fetch_size | 非零值,指定JDBC抓取數量的大小 (調用Statement.setFetchSize()). hibernate.jdbc.batch_size | 非零值,允許Hibernate使用JDBC2的批量更新.取值 建議取5到30之間的值 hibernate.jdbc.batch_versioned_data | 如果你想讓你的JDBC驅動從executeBatch()返回正確的行計數 , 那么將此屬性設為true(開啟這個選項通常是安全的). 同時,Hibernate將為自動版本化的數據使用批量DML. 默認值為false.eg. true | false hibernate.jdbc.factory_class | 選擇一個自定義的Batcher. 多數應用程序不需要這個配置屬性.eg. classname.of.Batcher hibernate.jdbc.use_scrollable_resultset | 允許Hibernate使用JDBC2的可滾動結果集. 只有在使用用戶提供的JDBC連接時,這個選項才是必要的, 否則Hibernate會使用連接的元數據.取值 true | false hibernate.jdbc.use_streams_for_binary | 在JDBC讀寫binary (二進制)或serializable (可序列化) 的類型時使用流(stream)(系統級屬性).取值 true | false hibernate.jdbc.use_get_generated_keys | 在數據插入數據庫之后,允許使用JDBC3 PreparedStatement.getGeneratedKeys() 來獲取數據庫生成的key(鍵)。需要JDBC3+驅動和JRE1.4+, 如果你的數據庫驅動在使用Hibernate的標 識生成器時遇到問題,請將此值設為false. 默認情況下將使用連接的元數據來判定驅動的能力.取值 true|false hibernate.connection.provider_class | 自定義ConnectionProvider的類名, 此類用來向Hibernate提供JDBC連接.取值 classname.of.ConnectionProvider hibernate.connection.isolation | 設置JDBC事務隔離級別. 查看java.sql.Connection來了解各個值的具體意義, 但請注意多數數據庫都不支持所有的隔離級別.取值 1, 2, 4, 8 hibernate.connection.autocommit | 允許被緩存的JDBC連接開啟自動提交(autocommit) (不建議).取值 true | false hibernate.connection.release_mode | 指定Hibernate在何時釋放JDBC連接. 默認情況下,直到Session被顯式關閉或被斷開連接時,才會釋放JDBC連接. 對于應用程序服務器的JTA數據源, 你應當使用after_statement, 這樣在每次JDBC調用后,都會主動的釋放連接. 對于非JTA的連接, 使用after_transaction在每個事務結束時釋放連接是合理的. auto將為JTA和CMT事務策略選擇after_statement, 為JDBC事務策略選擇after_transaction.取值 on_close | after_transaction | after_statement | auto hibernate.connection.Hibernate 緩沖屬性| 將JDBC屬性propertyName傳遞到DriverManager.getConnection()中去. hibernate.jndi. | 將屬性propertyName傳遞到JNDI InitialContextFactory中去. ---------------------------------------------------------------------------------------------------------------------------------------------------------------------
---------------------------------------------------------------------------------------------------------------------------------------------------------------------- |屬性名 | 用途 ---------------------------------------------------------------------------------------------------------------------------------------------------------------------- |hibernate.cache.provider_class | 自定義的CacheProvider的類名. 取值 classname.of.CacheProvider |hibernate.cache.use_minimal_puts | 以頻繁的讀操作為代價, 優化二級緩存來最小化寫操作. 在Hibernate3中,這個設置對的集群緩存非常有用, 對集群緩存的實現而言,默認是開啟的.取值 true|false |hibernate.cache.use_query_cache | 允許查詢緩存, 個別查詢仍然需要被設置為可緩存的.取值 true|false |hibernate.cache.use_second_level_cache | 能用來完全禁止使用二級緩存. 對那些在類的映射定義中指定Hibernate 事務屬性的類,會默認開啟二級緩存.取值 true|false |hibernate.cache.query_cache_factory | 自定義實現QueryCache接口的類名, 默認為內建的StandardQueryCache.取值 classname.of.QueryCache |hibernate.cache.region_prefix | 二級緩存區域名的前綴.取值 prefix |hibernate.cache.use_structured_entries | 強制Hibernate以更人性化的格式將數據存入二級緩存.取值 true|false ----------------------------------------------------------------------------------------------------------------------------------------------------------------------
--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |屬性名 | 用途 --------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |hibernate.transaction.factory_class | 一個TransactionFactory的類名, 用于Hibernate Transaction API (默認為JDBCTransactionFactory).取值 classname.of.TransactionFactory |jta.UserTransaction | 一個JNDI名字,被JTATransactionFactory用來從應用服務器獲取JTA UserTransaction.取值 jndi/composite/name |hibernate.transaction.manager_lookup_class | 一個TransactionManagerLookup的類名 - 當使用JVM級緩存,或在JTA環境中使用hilo生成器的時候需要該類.取值 classname.of.TransactionManagerLookup |hibernate.transaction.flush_before_completion | 如果開啟, session在事務完成后將被自動清洗(flush)。 現在更好的方法是使用自動session上下文管理。取值 true | false |hibernate.transaction.auto_close_session | 如果開啟, session在事務完成后將被自動關閉。 現在更好的方法是使用自動session上下文管理。取值 true | false ---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------方言
---------------------------------------------------------------------------------- |RDBMS | 方言 ---------------------------------------------------------------------------------- |DB2 | org.hibernate.dialect.DB2Dialect |DB2 AS/400 | org.hibernate.dialect.DB2400Dialect |DB2 OS390 | org.hibernate.dialect.DB2390Dialect |PostgreSQL | org.hibernate.dialect.PostgreSQLDialect |MySQL | org.hibernate.dialect.MySQLDialect |MySQL with InnoDB | org.hibernate.dialect.MySQLInnoDBDialect |MySQL with MyISAM | org.hibernate.dialect.MySQLMyISAMDialect |Oracle (any version) | org.hibernate.dialect.OracleDialect |Oracle 9i/10g | org.hibernate.dialect.Oracle9Dialect |Sybase | org.hibernate.dialect.SybaseDialect |Sybase Anywhere | org.hibernate.dialect.SybaseAnywhereDialect |Microsoft SQL Server | org.hibernate.dialect.SQLServerDialect |SAP DB | org.hibernate.dialect.SAPDBDialect |Informix | org.hibernate.dialect.InformixDialect |HypersonicSQL | org.hibernate.dialect.HSQLDialect |Ingres | org.hibernate.dialect.IngresDialect |Progress | org.hibernate.dialect.ProgressDialect |Mckoi SQL | org.hibernate.dialect.MckoiDialect |Interbase | org.hibernate.dialect.InterbaseDialect |Pointbase | org.hibernate.dialect.PointbaseDialect |FrontBase | org.hibernate.dialect.FrontbaseDialect |Firebird | org.hibernate.dialect.FirebirdDialect ----------------------------------------------------------------------------------其他屬性
------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------ |屬性名 用途 ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------ |hibernate.current_session_context_class | 為"當前" Session指定一個(自定義的)策略。eg. jta | thread | custom.Class |hibernate.query.factory_class | 選擇HQL解析器的實現.取值 org.hibernate.hql.ast.ASTQueryTranslatorFactory or org.hibernate.hql.classic.ClassicQueryTranslatorFactory |hibernate.query.substitutions | 將Hibernate查詢中的符號映射到SQL查詢中的符號 (符號可能是函數名或常量名字).取值 hqlLiteral=SQL_LITERAL, hqlFunction=SQLFUNC |hibernate.hbm2ddl.auto | 在SessionFactory創建時,自動檢查數據庫結構,或者將數據庫schema的DDL導出到數據庫. 使用 create-drop時,在顯式關閉SessionFactory時,將drop掉數據庫schema.取值 validate | update | create | create-drop |hibernate.cglib.use_reflection_optimizer | 開啟CGLIB來替代運行時反射機制(系統級屬性). 反射機制有時在除錯時比較有用. 注意即使關閉這個優化, Hibernate還是需要CGLIB. 你不能在hibernate.cfg.xml中設置此屬性取值 true | false ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------二、hibernate.xmls配置
oracle.jdbc.driver.OracleDriver jdbc:oracle:thin:@localhost:1521:orcl system sa org.hibernate.dialect.Oracle10gDialect true true validate thread 10 false
hibernate配置文件可以有兩種方式:官方推薦的XML配置文件和屬性配置文件。我們大都采用XML方式的配置,因為結構良好,配置靈活,可讀性強。而且可以在XML中直接配置映射文件而屬性文件則不行。但是我們可能忽略的一個問題是:hibernate首先查找的配置文件卻是屬性配置文件hibernate.properties。
Hibernate首先去找了hibernate.properties配置文件,但是沒找到。然后創建字節碼支持器,用到cglib,之后用了時間戳控制,之后才是讀取hibernate.cfg.xml配置文件。這些在最前面的日志信息我們可能會忽略它,但是我們要明白hibernate的一些加載原理。
為什么使用properties配置hibernate?在實際開發中一般都是hibernate.properties和hibernate.cfg.xml結合使用,這樣可以使得結果更加清晰,便于更改數據庫連接配置,需要修改屬性就去hibernate.properties文件修改,需要修改映射配置就在hibernate.cfg.xml中去修改。使用hibernate.properties配置
hibernate.connection.driver_class=oracle.jdbc.driver.OracleDriver hibernate.connection.url=jdbc:oracle:thin:@localhost:1521:orcl hibernate.connection.username=root hibernate.connection.password=password hibernate.dialect=org.hibernate.dialect.Oracle10gDialect hibernate.show_sql=true hibernate.format_sql=true hbm2ddl.auto=validate current_session_context_class=thread hibernate.jdbc.batch_size=10 hibernate.cache.use_second_level_cache=falsehibernate 配置
classpath:jdbc.properties ${hibernate.connection.driver_class} ${hibernate.connection.url} ${hibernate.connection.username} ${hibernate.connection.password} ${hibernate.dialect} ${hibernate.show_sql} ${hibernate.format_sql} ${hibernate.connection.url} ${current_session_context_class} ${hibernate.jdbc.batch_size} ${use_second_level_cache}
可能寫的有點簡單,但意思是這個意思
如果和spring 一起用,那么幾乎一樣。
jdbc.properties
jdbc.driverClassName=com.mysql.jdbc.Driver jdbc.url=jdbc:mysql://localhost:3306/demo jdbc.username=root jdbc.password=password jdbc.initialPoolSize=5 jdbc.minPoolSize=5 jdbc.maxPoolSize=100spring-applicationContext.xml
classpath:jdbc.properties
如果實體配置完后,如果是幾個的話,還好,要是多起來,那么你將會瘋,所以提供以下解決實體類加載到hibernate中。
1.自動掃包 2.注冊映射文件<這個在上面其實已經用過了>1.自動掃包 掃描一個包下的文件時:
需要掃描不同包下的文件時:
classpath:entity classpath:com.smilesnake..entity
2.注冊映射文件
本人提供第三種配置方案----自定義
/WEB-INF/config/jdbc.properties
/WEB-INF/config/jdbc.properties hibernate.dialect=${hibernate.dialect} hibernate.show_sql=false hibernate.format_sql=false hibernate.query.substitutions=true 1, false 0 hibernate.jdbc.fetch_size=20 hibernate.connection.autocommit=true hibernate.connection.release_mode=auto hibernate.cache.use_query_cache=true hibernate.cache.use_second_level_cache=true hibernate.cache.use_structured_entries=true
當然,這上面的配置省略了很多,只提供了hibernate部分
jdbc.properties#mysql jdbc.driverClassName=com.mysql.jdbc.Driver jdbc.url=jdbc:mysql://127.0.0.1:3306/smilesnake?characterEncoding=UTF-8 jdbc.username=smilesnake jdbc.password=password hibernate.db=mysql hibernate.dialect=org.hibernate.dialect.MySQL5Dialect #oracle #jdbc.driverClassName=oracle.jdbc.driver.OracleDriver #jdbc.url=jdbc:oracle:thin:@192.168.0.132:1521:orcl #jdbc.username=smilesnake #jdbc.password=password #hibernate.db=oracle #hibernate.dialect=org.hibernate.dialect.Oracle10gDialect #sqlserver #jdbc.driverClassName=com.microsoft.sqlserver.jdbc.SQLServerDriver #jdbc.url=jdbc:sqlserver://192.168.0.132:1433;DatabaseName=smilesnake #jdbc.username=smilesnake #jdbc.password=password #hibernate.db=sqlserver #hibernate.dialect=org.hibernate.dialect.SQLServerDialect #db2 #jdbc.driverClassName=com.ibm.db2.jcc.DB2Driver #jdbc.url=jdbc:db2://localhost:50000/smilesnake #jdbc.username=smilesnake #jdbc.password=password #hibernate.db=db2 #hibernate.dialect=org.hibernate.dialect.DB2Dialect #mysql hibernate.hbm.jeecms.core=classpath*:/com/smilesnake/core/entity/hbm/common/*.hbm.xml hibernate.hbm.jeecms.cms=classpath*:/com/smilesnake/cms/entity/main/hbm/common/*.hbm.xml hibernate.hbm.jeecms.assist=classpath*:/com/smilesnake/cms/entity/assist/hbm/common/*.hbm.xml cpool.checkoutTimeout=5000 cpool.minPoolSize=20 cpool.maxPoolSize=100 cpool.maxIdleTime=7200 cpool.maxIdleTimeExcessConnections=1800 cpool.acquireIncrement=10
想用哪個就打開哪個,不想用哪個就注釋掉
PropertyUtils.javaimport java.io.File; import java.io.FileInputStream; import java.io.FileNotFoundException; import java.io.IOException; import java.io.InputStream; import java.util.ArrayList; import java.util.Collections; import java.util.Enumeration; import java.util.HashMap; import java.util.List; import java.util.Map; import java.util.Properties; import java.util.Set; import java.util.TreeSet; import org.springframework.beans.BeansException; import org.springframework.beans.factory.BeanFactory; import org.springframework.beans.factory.BeanFactoryAware; public class PropertyUtils implements BeanFactoryAware { /** * 從指定的properties 得到 以prefix開頭的配置,并將其路徑放到一個list中后返回此list * @param prefix * @return list */ public ListgetList(String prefix) { //判斷配置文件或者前綴不為空,為空返回一個空的集合 if (properties == null || prefix == null) { return Collections.emptyList(); } List list = new ArrayList (); // 返回屬性列表中所有鍵的枚舉,如果在主屬性列表中未找到同名的鍵,則包括默認屬性列表中不同的鍵。 Enumeration> en = properties.propertyNames(); String key; //遍歷 Enumeration while (en.hasMoreElements()) { key = (String) en.nextElement(); //判斷是否以hibernate.hbm開頭 //意為著讀取properties文件中的herbernate.hbm開頭的配置, if (key.startsWith(prefix)) { list.add(properties.getProperty(key)); } } return list; } /** * 從指定的properties 得到 以prefix開頭的配置,并將其路徑放到一個Set中后返回此Set * @param prefix * @return Set */ public Set getSet(String prefix) { if (properties == null || prefix == null) { return Collections.emptySet(); } Set set=new TreeSet (); Enumeration> en = properties.propertyNames(); String key; while (en.hasMoreElements()) { key = (String) en.nextElement(); if (key.startsWith(prefix)) { set.add(properties.getProperty(key)); } } return set; } /** * 從指定的properties 得到 以prefix開頭的配置,并將其路徑放到一個Map中后返回此Map * @param prefix * @return Map */ public Map getMap(String prefix) { if (properties == null || prefix == null) { return Collections.emptyMap(); } Map map = new HashMap (); Enumeration> en = properties.propertyNames(); String key; int len = prefix.length(); while (en.hasMoreElements()) { key = (String) en.nextElement(); if (key.startsWith(prefix)) { map.put(key.substring(len), properties.getProperty(key)); } } return map; } /** * Properties 繼承了HashTable * 從指定的properties 得到 以prefix開頭的配置,并將其路徑放到一個Properties中后返回此Properties * @param prefix * @return Properties */ public Properties getProperties(String prefix) { Properties props = new Properties(); if (properties == null || prefix == null) { return props; } Enumeration> en = properties.propertyNames(); String key; int len = prefix.length(); while (en.hasMoreElements()) { key = (String) en.nextElement(); if (key.startsWith(prefix)) { props.put(key.substring(len), properties.getProperty(key)); } } return props; } //此方法分別在config/jeecms/jeecms-servlet-admin-action.xml調用("hibernate.db") /** * 從指定的properties 得到 以prefix開頭的配置,并將其路徑放到一個String中后返回此String * @param prefix * @return String */ public String getPropertiesString(String prefix) { String property = ""; if (properties == null || prefix == null) { return property; } Enumeration> en = properties.propertyNames(); String key; while (en.hasMoreElements()) { key = (String) en.nextElement(); if (key.equals(prefix)) { return properties.getProperty(key); } } return property; } //此方法分別在config/jeecms/jeecms-context.xml調用("directive.") //此方法分別在config/jeecms/jeecms-servlet-front-action.xml調用("directive.") /** * 從指定的properties 得到 以prefix開頭的配置,并將其路徑放到一個Map中后返回此Map * @param prefix * @return */ public Map getBeanMap(String prefix) { Map keyMap = getMap(prefix); if (keyMap.isEmpty()) { return Collections.emptyMap(); } Map resultMap = new HashMap (keyMap.size()); String key, value; for (Map.Entry entry : keyMap.entrySet()) { key = entry.getKey(); value = entry.getValue(); resultMap.put(key, beanFactory.getBean(value, Object.class)); } return resultMap; } /** * 讀取file文件后將文件信息保存在props * @param file * @return */ public static Properties getProperties(File file) { Properties props = new Properties(); InputStream in; try { in = new FileInputStream(file); //讀取此文件 props.load(in); } catch (FileNotFoundException e) { // TODO Auto-generated catch block e.printStackTrace(); } catch (IOException e) { // TODO Auto-generated catch block e.printStackTrace(); } return props; } /** * 讀取指定文件中的指定key的value值, * @param file * @param key * @return String */ public static String getPropertyValue(File file,String key) { Properties props=getProperties(file); return (String) props.get(key); } private BeanFactory beanFactory; private Properties properties; public void setProperties(Properties properties) { this.properties = properties; } public void setBeanFactory(BeanFactory beanFactory) throws BeansException { this.beanFactory = beanFactory; }
}
如果有侵權,馬上刪除
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/68383.html
摘要:旨在記錄自己的學習過程,方便日后遇到問題是及時查閱復習,另一方面也希望能幫助像筆者一樣從來沒使用過的人快速熟悉。 這篇文章主要記錄的是本人學習使用IntelliJ IDEA的筆記,可能不是特別的詳細。旨在記錄自己的學習過程,方便日后遇到問題是及時查閱復習,另一方面也希望能幫助像筆者一樣從來沒使用過IDEA的人快速熟悉IDEA。文章錯誤之處還請各位大佬批評指正。(文末有本人的微信公眾號,...
摘要:在使用作為應用時推薦使用作為開發工具導入相應的的包到文件下的目錄下關于開發中導入的說明在此提供一個包下載鏈接,地址百度云盤下載好以后解壓到某個文件夾里解壓好以后,開發所需要的包在解壓后的包下,將該文件夾下的包復制到項目中另外還需 1.在使用Hibernate作為orm應用時推薦使用myeclipse作為開發工具2.導入相應的Hibernate的jar包到webroot文件下的lib目錄...
摘要:時間年月日星期二說明本文部分內容均來自慕課網。文件如下在目錄下,創建文件指定映射文件的路徑注解映射實體類可選,對應數據庫中的一個表。 時間:2017年07月11日星期二說明:本文部分內容均來自慕課網。@慕課網:http://www.imooc.com教學源碼:無學習源碼:https://github.com/zccodere/s... 第一章:類級別注解 1-1 本章簡介 本章簡介 H...
摘要:本文速覽本篇文章是我為接下來的源碼分析系列文章寫的一個導讀文章。年該項目從基金會遷出,并改名為。同期,停止維護。符號所在的行則是表示的執行結果。同時,使用無需處理受檢異常,比如。另外,把寫在配置文件中,進行集中管理,利于維護。 1.本文速覽 本篇文章是我為接下來的 MyBatis 源碼分析系列文章寫的一個導讀文章。本篇文章從 MyBatis 是什么(what),為什么要使用(why),...
閱讀 2725·2021-11-22 13:52
閱讀 1189·2021-10-14 09:43
閱讀 3646·2019-08-30 15:56
閱讀 2956·2019-08-30 13:22
閱讀 3279·2019-08-30 13:10
閱讀 1570·2019-08-26 13:45
閱讀 1105·2019-08-26 11:47
閱讀 2796·2019-08-23 18:13