ibatis簡(jiǎn)單實(shí)現(xiàn)與配置
更新時(shí)間:2009年01月07日 23:01:47 作者:
ibatis與hibernate一樣,同樣也是一種OR框架,OR框架有很多種,相對(duì)用的比較多的就是hibernate與ibatis,ibatis是一種白自動(dòng)化的ORM的實(shí)現(xiàn)
那我們什么時(shí)候可以用到ibatis呢,我們用hibernate的時(shí)候會(huì)發(fā)現(xiàn),有的時(shí)候hibernate不支持一些特別精確的查詢,這個(gè)時(shí)候我們完全可以用到ibatis,因?yàn)樗前胱詣?dòng)化的。一會(huì)我們可以看到,他的查詢語(yǔ)句是我們?cè)谂渲梦募ml中寫的。hibernate可以用到一些大型的項(xiàng)目當(dāng)中,ibatis我們可以應(yīng)用到一些小型的項(xiàng)目當(dāng)中。
下面我們看下ibatis的具體實(shí)現(xiàn),hibernate中,我們都知道有一個(gè)hibernate.cfg.xml配置文件,和另一個(gè)*.hbm.xml配置文件,在ibatis中,我們同樣也有兩個(gè)配置文件,一個(gè)為SqlMapConfig.xml另一個(gè)為*.xml下面我們具體的看下兩個(gè)配置文件中的具體配置方法。
SqlMapConfig.xml配置方法
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE sqlMapConfig
PUBLIC "-//iBATIS.com//DTD SQL Map Config 2.0//EN"
"http://www.ibatis.com/dtd/sql-map-config-2.dtd">
<sqlMapConfig>
<settings cacheModelsEnabled="true"
enhancementEnabled="true"
lazyLoadingEnabled="true"
errorTracingEnabled="true"
maxRequests="32"
maxSessions="10"
maxTransactions="5"
useStatementNamespaces="false" />
<!-- maxrequest 同時(shí)執(zhí)行sql語(yǔ)句的最大條數(shù) 最好至少是maxTransactions的10倍數(shù) 而且大于maxSession
maxTransactions 同時(shí)進(jìn)入SqlMapClient.startTransaction()的 最大線程數(shù)
maxSession 同一時(shí)間段內(nèi) 最大session數(shù) 大于maxTransactions 小于maxRequest
cacheModelsEnabled 全局性的啟用或者禁用SqlMapClient的所有緩存model true為啟用 默認(rèn)為啟用
lazyLoadingEnabled 全局性的啟用或者禁用SqlMapClient的所有延遲加載,調(diào)試程序使用 true為啟用 默認(rèn)為啟用
enhancementEnabled 全局性的啟用或者禁用運(yùn)行時(shí)字節(jié)碼增強(qiáng) false為禁用 默認(rèn)為禁用
useStatementNamespaces 如果啟用本屬性,必須使用權(quán)限定名來(lái)引用mappedstatement。
這是由sql-map的名稱和mapped-statment的名稱合成,默認(rèn)為false 禁用。
-->
<transactionManager type="JDBC">
<dataSource type="SIMPLE">
<property name="JDBC.Driver" value="com.mysql.jdbc.Driver"/>
<property name="JDBC.ConnectionURL" value="jdbc:mysql://localhost/sample"/>
<property name="JDBC.Username" value="root"/>
<property name="JDBC.Password" value="admin"/>
<!-- transactionManager元素為SQL Map配置事務(wù)管理服務(wù)
type指定所使用的管理器類型可以為JDBC JTA EXTERNAL
datasource元素是transactionManager的一部分
為SQL Map數(shù)據(jù)源設(shè)置了一些列參數(shù)。
dataSource type為 是根據(jù)選擇鏈接數(shù)據(jù)庫(kù)的方式?jīng)Q定的
peoperty中的JDBC.Driver為 驅(qū)動(dòng)
ConnectionURL為鏈接地址
Username為訪問數(shù)據(jù)庫(kù)的用戶名
Password為訪問數(shù)據(jù)庫(kù)的密碼
-->
<property name="Pool.MaximumIdleConnections" value="5" />
<property name="Pool.MaximumCheckoutTime" value="120000" />
<property name="Pool.TimeToWait" value="500" />
<property name="Pool.PingQuery" value="select 1 from sample" />
<property name="Pool.PingEnabled" value="false" />
<property name="Pool.PingConnectionsOlderThan" value="1" />
<property name="Pool.PingConnectionsNotUsedFor" value="1" />
<!-- MaximumIdleConnections數(shù)據(jù)庫(kù)連接池中允許的掛起(idle)連接數(shù)
MaximumCheckoutTime數(shù)據(jù)庫(kù)聯(lián)接池中,連接被某個(gè)任務(wù)所允許占用的最大時(shí)間,
如果超過這個(gè)時(shí)間限定,連接將被強(qiáng)制收回。(毫秒)
TimeToWait當(dāng)線程試圖從連接池中獲取連接時(shí),連接池中無(wú)可用連接可供使用,
此時(shí)線程將進(jìn)入等待狀態(tài),直到池中出現(xiàn)空閑連接。
此參數(shù)設(shè)定了線程所允許等待的最長(zhǎng)時(shí)間。(毫秒)
PingQuery數(shù)據(jù)庫(kù)連接狀態(tài)檢測(cè)語(yǔ)句。某些數(shù)據(jù)庫(kù)在連接在某段時(shí)間持續(xù)處于空閑
狀態(tài)時(shí)會(huì)將其斷開。而連接池管理器將通過此語(yǔ)句檢測(cè)池中連接是否可用。
檢測(cè)語(yǔ)句應(yīng)該是一個(gè)最簡(jiǎn)化的無(wú)邏輯SQL。如“select 1 from t_user”,
如果執(zhí)行此語(yǔ)句成功,連接池管理器將認(rèn)為此連接處于可用狀態(tài)
PingEnabled是否允許檢測(cè)連接狀態(tài)。
PingConnectionsOlderThan對(duì)持續(xù)連接時(shí)間超過設(shè)定值(毫秒)的連接進(jìn)行檢測(cè)。
Pool.PingConnectionsNotUsedFor對(duì)空閑超過設(shè)定值(毫秒)的連接進(jìn)行檢測(cè)。
-->
</dataSource>
</transactionManager>
<sqlMap resource="com/kobe/map/User.xml" />
<!-- sqlmap源的 位置"包名/ .xml注意包中間有.的時(shí)候用/代替" -->
</sqlMapConfig>
<!-- 注意 1.0允許配置多個(gè)數(shù)據(jù)源,這引起了一些不好的實(shí)現(xiàn),因此
2.0版本只允許一個(gè)數(shù)據(jù)源,要使用多個(gè)部署/配置參數(shù),您最好使用多個(gè)屬性文件,
不同的屬性文件,或在創(chuàng)建SQL Map時(shí)傳入不同的屬性文件。 -->
里面的配置文件,對(duì)我們初級(jí)入門的人來(lái)說,主要的配置就是連接數(shù)據(jù)庫(kù)的配置。
下面,我們?cè)诳聪?.xml中的配置
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE sqlMap
PUBLIC "-//iBATIS.com//DTD SQL Map 2.0//EN"
"http://www.ibatis.com/dtd/sql-map-2.dtd">
<sqlMap namespace="User"> <!-- 映射文件名稱 -->
<typeAlias alias="user" type="com.kobe.map.User"/> <!-- 給對(duì)應(yīng)的類取別名 -->
<!-- sql語(yǔ)句 <![CDATA[可以避免SQL 中與XML 規(guī)范相沖突的字符對(duì)XML映射文件的合法性造成影響。
-->
<select id="getUser" parameterClass="java.lang.String"
resultClass="user">
<!-- parameterClass是參數(shù)類型
resultClass是結(jié)果的類型
如果sql語(yǔ)句包括參數(shù), 那么格式是#id# -->
<![CDATA[ select name,sex from t_user where name = #name#]]>
</select>
<select id="getAllUser" resultClass="user">
<![CDATA[ select name, sex from t_user where name = #name# ]]>
</select>
<update id="updateUser" parameterClass="user">
<![CDATA[ UPDATE t_user SET name=#name#, sex=#sex# WHERE id = #id# ]]>
</update>
<delete id="deleteUser" parameterClass="user">
delete from t_user where id=#id#
</delete>
<insert id="insertUser" parameterClass="user">
<![CDATA[ insert into t_user (id,name,sex) values (#id#,#name#,#sex#) ]]>
</insert>
</sqlMap>
這里面配置文件我們可以看出來(lái)了。這里體現(xiàn)了ibatis半自動(dòng)化的體現(xiàn),因?yàn)樗膕ql語(yǔ)句并不是自動(dòng)生成,而是我們自己寫的,所以這樣我們可以執(zhí)行更精確的查詢。
下面我們?cè)诳聪耇est實(shí)現(xiàn)
import java.sql.SQLException;
import com.ibatis.common.resources.Resources;
import com.ibatis.sqlmap.client.SqlMapClientBuilder;
public class Test {
public static void main(String args[]){
//首先初始化iBatis獲得一個(gè)SqlMapClient對(duì)象
String resource = "com/kobe/map/SqlMapConfig.xml";
com.ibatis.sqlmap.client.SqlMapClient sqlMap = null;
try {
java.io.Reader reader = com.ibatis.common.resources.Resources
.getResourceAsReader(resource);
sqlMap = SqlMapClientBuilder.buildSqlMapClient(reader);
} catch (Exception e) {
e.printStackTrace();
}
// sqlMap系統(tǒng)初始化完畢,開始執(zhí)行update操作
try {
sqlMap.startTransaction();
User user = new User();
//user.setId(24);
//user.setName("lzq");
//user.setSex(24);
//sqlMap.insert("insertUser", user);
//user.setId(24);
//user.setName("kobelzq");
//user.setSex(24);
//sqlMap.update("updateUser", user); //key為User xml中配置的id名字 鍵為bean的名字
user.setId(2);
sqlMap.delete("deleteUser", user);
sqlMap.commitTransaction();
} catch (SQLException e) {
System.out.println(e.getMessage());
} finally {
try {
sqlMap.endTransaction();
} catch (SQLException e) {
e.printStackTrace();
}
System.out.println("操作成功");
}
}
}
上面我加注釋的地方,大家可以根據(jù)不同的需要,測(cè)試下不同的效果,我測(cè)試了三個(gè)效果,分別為增,刪,改,查詢大家要是感興趣的話,可以自己寫下。我這里少寫了一個(gè)持久類,持久類的寫法大家都熟悉,我就不在這里給大家展示了,無(wú)非就是get與set方法,大家可以自己實(shí)現(xiàn)一下。
下面我們看下ibatis的具體實(shí)現(xiàn),hibernate中,我們都知道有一個(gè)hibernate.cfg.xml配置文件,和另一個(gè)*.hbm.xml配置文件,在ibatis中,我們同樣也有兩個(gè)配置文件,一個(gè)為SqlMapConfig.xml另一個(gè)為*.xml下面我們具體的看下兩個(gè)配置文件中的具體配置方法。
SqlMapConfig.xml配置方法
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE sqlMapConfig
PUBLIC "-//iBATIS.com//DTD SQL Map Config 2.0//EN"
"http://www.ibatis.com/dtd/sql-map-config-2.dtd">
<sqlMapConfig>
<settings cacheModelsEnabled="true"
enhancementEnabled="true"
lazyLoadingEnabled="true"
errorTracingEnabled="true"
maxRequests="32"
maxSessions="10"
maxTransactions="5"
useStatementNamespaces="false" />
<!-- maxrequest 同時(shí)執(zhí)行sql語(yǔ)句的最大條數(shù) 最好至少是maxTransactions的10倍數(shù) 而且大于maxSession
maxTransactions 同時(shí)進(jìn)入SqlMapClient.startTransaction()的 最大線程數(shù)
maxSession 同一時(shí)間段內(nèi) 最大session數(shù) 大于maxTransactions 小于maxRequest
cacheModelsEnabled 全局性的啟用或者禁用SqlMapClient的所有緩存model true為啟用 默認(rèn)為啟用
lazyLoadingEnabled 全局性的啟用或者禁用SqlMapClient的所有延遲加載,調(diào)試程序使用 true為啟用 默認(rèn)為啟用
enhancementEnabled 全局性的啟用或者禁用運(yùn)行時(shí)字節(jié)碼增強(qiáng) false為禁用 默認(rèn)為禁用
useStatementNamespaces 如果啟用本屬性,必須使用權(quán)限定名來(lái)引用mappedstatement。
這是由sql-map的名稱和mapped-statment的名稱合成,默認(rèn)為false 禁用。
-->
<transactionManager type="JDBC">
<dataSource type="SIMPLE">
<property name="JDBC.Driver" value="com.mysql.jdbc.Driver"/>
<property name="JDBC.ConnectionURL" value="jdbc:mysql://localhost/sample"/>
<property name="JDBC.Username" value="root"/>
<property name="JDBC.Password" value="admin"/>
<!-- transactionManager元素為SQL Map配置事務(wù)管理服務(wù)
type指定所使用的管理器類型可以為JDBC JTA EXTERNAL
datasource元素是transactionManager的一部分
為SQL Map數(shù)據(jù)源設(shè)置了一些列參數(shù)。
dataSource type為 是根據(jù)選擇鏈接數(shù)據(jù)庫(kù)的方式?jīng)Q定的
peoperty中的JDBC.Driver為 驅(qū)動(dòng)
ConnectionURL為鏈接地址
Username為訪問數(shù)據(jù)庫(kù)的用戶名
Password為訪問數(shù)據(jù)庫(kù)的密碼
-->
<property name="Pool.MaximumIdleConnections" value="5" />
<property name="Pool.MaximumCheckoutTime" value="120000" />
<property name="Pool.TimeToWait" value="500" />
<property name="Pool.PingQuery" value="select 1 from sample" />
<property name="Pool.PingEnabled" value="false" />
<property name="Pool.PingConnectionsOlderThan" value="1" />
<property name="Pool.PingConnectionsNotUsedFor" value="1" />
<!-- MaximumIdleConnections數(shù)據(jù)庫(kù)連接池中允許的掛起(idle)連接數(shù)
MaximumCheckoutTime數(shù)據(jù)庫(kù)聯(lián)接池中,連接被某個(gè)任務(wù)所允許占用的最大時(shí)間,
如果超過這個(gè)時(shí)間限定,連接將被強(qiáng)制收回。(毫秒)
TimeToWait當(dāng)線程試圖從連接池中獲取連接時(shí),連接池中無(wú)可用連接可供使用,
此時(shí)線程將進(jìn)入等待狀態(tài),直到池中出現(xiàn)空閑連接。
此參數(shù)設(shè)定了線程所允許等待的最長(zhǎng)時(shí)間。(毫秒)
PingQuery數(shù)據(jù)庫(kù)連接狀態(tài)檢測(cè)語(yǔ)句。某些數(shù)據(jù)庫(kù)在連接在某段時(shí)間持續(xù)處于空閑
狀態(tài)時(shí)會(huì)將其斷開。而連接池管理器將通過此語(yǔ)句檢測(cè)池中連接是否可用。
檢測(cè)語(yǔ)句應(yīng)該是一個(gè)最簡(jiǎn)化的無(wú)邏輯SQL。如“select 1 from t_user”,
如果執(zhí)行此語(yǔ)句成功,連接池管理器將認(rèn)為此連接處于可用狀態(tài)
PingEnabled是否允許檢測(cè)連接狀態(tài)。
PingConnectionsOlderThan對(duì)持續(xù)連接時(shí)間超過設(shè)定值(毫秒)的連接進(jìn)行檢測(cè)。
Pool.PingConnectionsNotUsedFor對(duì)空閑超過設(shè)定值(毫秒)的連接進(jìn)行檢測(cè)。
-->
</dataSource>
</transactionManager>
<sqlMap resource="com/kobe/map/User.xml" />
<!-- sqlmap源的 位置"包名/ .xml注意包中間有.的時(shí)候用/代替" -->
</sqlMapConfig>
<!-- 注意 1.0允許配置多個(gè)數(shù)據(jù)源,這引起了一些不好的實(shí)現(xiàn),因此
2.0版本只允許一個(gè)數(shù)據(jù)源,要使用多個(gè)部署/配置參數(shù),您最好使用多個(gè)屬性文件,
不同的屬性文件,或在創(chuàng)建SQL Map時(shí)傳入不同的屬性文件。 -->
里面的配置文件,對(duì)我們初級(jí)入門的人來(lái)說,主要的配置就是連接數(shù)據(jù)庫(kù)的配置。
下面,我們?cè)诳聪?.xml中的配置
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE sqlMap
PUBLIC "-//iBATIS.com//DTD SQL Map 2.0//EN"
"http://www.ibatis.com/dtd/sql-map-2.dtd">
<sqlMap namespace="User"> <!-- 映射文件名稱 -->
<typeAlias alias="user" type="com.kobe.map.User"/> <!-- 給對(duì)應(yīng)的類取別名 -->
<!-- sql語(yǔ)句 <![CDATA[可以避免SQL 中與XML 規(guī)范相沖突的字符對(duì)XML映射文件的合法性造成影響。
-->
<select id="getUser" parameterClass="java.lang.String"
resultClass="user">
<!-- parameterClass是參數(shù)類型
resultClass是結(jié)果的類型
如果sql語(yǔ)句包括參數(shù), 那么格式是#id# -->
<![CDATA[ select name,sex from t_user where name = #name#]]>
</select>
<select id="getAllUser" resultClass="user">
<![CDATA[ select name, sex from t_user where name = #name# ]]>
</select>
<update id="updateUser" parameterClass="user">
<![CDATA[ UPDATE t_user SET name=#name#, sex=#sex# WHERE id = #id# ]]>
</update>
<delete id="deleteUser" parameterClass="user">
delete from t_user where id=#id#
</delete>
<insert id="insertUser" parameterClass="user">
<![CDATA[ insert into t_user (id,name,sex) values (#id#,#name#,#sex#) ]]>
</insert>
</sqlMap>
這里面配置文件我們可以看出來(lái)了。這里體現(xiàn)了ibatis半自動(dòng)化的體現(xiàn),因?yàn)樗膕ql語(yǔ)句并不是自動(dòng)生成,而是我們自己寫的,所以這樣我們可以執(zhí)行更精確的查詢。
下面我們?cè)诳聪耇est實(shí)現(xiàn)
import java.sql.SQLException;
import com.ibatis.common.resources.Resources;
import com.ibatis.sqlmap.client.SqlMapClientBuilder;
public class Test {
public static void main(String args[]){
//首先初始化iBatis獲得一個(gè)SqlMapClient對(duì)象
String resource = "com/kobe/map/SqlMapConfig.xml";
com.ibatis.sqlmap.client.SqlMapClient sqlMap = null;
try {
java.io.Reader reader = com.ibatis.common.resources.Resources
.getResourceAsReader(resource);
sqlMap = SqlMapClientBuilder.buildSqlMapClient(reader);
} catch (Exception e) {
e.printStackTrace();
}
// sqlMap系統(tǒng)初始化完畢,開始執(zhí)行update操作
try {
sqlMap.startTransaction();
User user = new User();
//user.setId(24);
//user.setName("lzq");
//user.setSex(24);
//sqlMap.insert("insertUser", user);
//user.setId(24);
//user.setName("kobelzq");
//user.setSex(24);
//sqlMap.update("updateUser", user); //key為User xml中配置的id名字 鍵為bean的名字
user.setId(2);
sqlMap.delete("deleteUser", user);
sqlMap.commitTransaction();
} catch (SQLException e) {
System.out.println(e.getMessage());
} finally {
try {
sqlMap.endTransaction();
} catch (SQLException e) {
e.printStackTrace();
}
System.out.println("操作成功");
}
}
}
上面我加注釋的地方,大家可以根據(jù)不同的需要,測(cè)試下不同的效果,我測(cè)試了三個(gè)效果,分別為增,刪,改,查詢大家要是感興趣的話,可以自己寫下。我這里少寫了一個(gè)持久類,持久類的寫法大家都熟悉,我就不在這里給大家展示了,無(wú)非就是get與set方法,大家可以自己實(shí)現(xiàn)一下。
您可能感興趣的文章:
- struts2+spring+ibatis框架整合實(shí)現(xiàn)增刪改查
- 在Spring使用iBatis及配置講解
- ibatis結(jié)合oracle批量插入三種方法的測(cè)評(píng)
- java~springboot~ibatis數(shù)組in查詢的實(shí)現(xiàn)方法
- ibatis遷移到mybatis3的注意事項(xiàng)
- 通過ibatis解決sql注入問題
- Mybatis報(bào)錯(cuò): org.apache.ibatis.exceptions.PersistenceException解決辦法
- Mybatis與Ibatis的區(qū)別
- 簡(jiǎn)單了解java ibatis #及$的區(qū)別和用法
相關(guān)文章
將ChatGPT接入微信實(shí)現(xiàn)智能回復(fù)功能
這篇文章主要介紹了將ChatGPT接入微信實(shí)現(xiàn)智能回復(fù)功能,本項(xiàng)目是基于ChatGPT的微信聊天機(jī)器人,通過?OpenAI?接口生成對(duì)話內(nèi)容,使用?itchat?實(shí)現(xiàn)微信消息的接收和自動(dòng)回復(fù),需要的朋友可以參考下2023-02-02微信小程序(應(yīng)用號(hào))組件詳細(xì)介紹
這篇文章主要介紹了微信小程序(應(yīng)用號(hào))組件詳細(xì)介紹的相關(guān)資料,需要的朋友可以參考下2016-09-09趁熱打鐵!HTTPGet與HTTPPost的區(qū)別詳解
這篇文章主要介紹了趁熱打鐵!HTTPGet與HTTPPost的區(qū)別詳解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-10-10thymeleaf實(shí)現(xiàn)th:each雙重多重嵌套功能
今天給大家分享一個(gè)使用 thymeleaf 實(shí)現(xiàn)一個(gè)動(dòng)態(tài)加載一二級(jí)文章分類的功能,本文通過代碼講解的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友參考下吧2019-11-11