欧美阿v视频在线大全_亚洲欧美中文日韩V在线观看_www性欧美日韩欧美91_亚洲欧美日韩久久精品

主頁(yè) > 知識(shí)庫(kù) > ibatis簡(jiǎn)單實(shí)現(xiàn)與配置

ibatis簡(jiǎn)單實(shí)現(xiàn)與配置

熱門(mén)標(biāo)簽:揭陽(yáng)外呼系統(tǒng)公司 地圖標(biāo)注植物名稱(chēng) 去哪里辦卡 地圖標(biāo)注審核工作怎么樣注冊(cè) 福建ai電銷(xiāo)機(jī)器人加盟公司 南召400電話(huà)辦理資費(fèi) 熱血傳奇沃瑪森林地圖標(biāo)注 鄭州中國(guó)移動(dòng)400電話(huà)申請(qǐng) 無(wú)錫電銷(xiāo)機(jī)器人銷(xiāo)售 招聘信息
那我們什么時(shí)候可以用到ibatis呢,我們用hibernate的時(shí)候會(huì)發(fā)現(xiàn),有的時(shí)候hibernate不支持一些特別精確的查詢(xún),這個(gè)時(shí)候我們完全可以用到ibatis,因?yàn)樗前胱詣?dòng)化的。一會(huì)我們可以看到,他的查詢(xún)語(yǔ)句是我們?cè)谂渲梦募ml中寫(xiě)的。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()的 最大線(xiàn)程數(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的名稱(chēng)和mapped-statment的名稱(chēng)合成,默認(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指定所使用的管理器類(lèi)型可以為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為訪(fǎng)問(wèn)數(shù)據(jù)庫(kù)的用戶(hù)名
Password為訪(fǎng)問(wèn)數(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í)間,
如果超過(guò)這個(gè)時(shí)間限定,連接將被強(qiáng)制收回。(毫秒)
TimeToWait當(dāng)線(xiàn)程試圖從連接池中獲取連接時(shí),連接池中無(wú)可用連接可供使用,
此時(shí)線(xiàn)程將進(jìn)入等待狀態(tài),直到池中出現(xiàn)空閑連接。
此參數(shù)設(shè)定了線(xiàn)程所允許等待的最長(zhǎng)時(shí)間。(毫秒)
PingQuery數(shù)據(jù)庫(kù)連接狀態(tài)檢測(cè)語(yǔ)句。某些數(shù)據(jù)庫(kù)在連接在某段時(shí)間持續(xù)處于空閑
狀態(tài)時(shí)會(huì)將其斷開(kāi)。而連接池管理器將通過(guò)此語(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í)間超過(guò)設(shè)定值(毫秒)的連接進(jìn)行檢測(cè)。
Pool.PingConnectionsNotUsedFor對(duì)空閑超過(guò)設(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í)入門(mén)的人來(lái)說(shuō),主要的配置就是連接數(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"> !-- 映射文件名稱(chēng) -->
typeAlias alias="user" type="com.kobe.map.User"/> !-- 給對(duì)應(yīng)的類(lèi)取別名 -->
!-- sql語(yǔ)句 ![CDATA[可以避免SQL 中與XML 規(guī)范相沖突的字符對(duì)XML映射文件的合法性造成影響。
-->
select id="getUser" parameterClass="java.lang.String"
resultClass="user">
!-- parameterClass是參數(shù)類(lèi)型
resultClass是結(jié)果的類(lèi)型
如果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)生成,而是我們自己寫(xiě)的,所以這樣我們可以執(zhí)行更精確的查詢(xún)。
下面我們?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)初始化完畢,開(kāi)始執(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è)效果,分別為增,刪,改,查詢(xún)大家要是感興趣的話(huà),可以自己寫(xiě)下。我這里少寫(xiě)了一個(gè)持久類(lèi),持久類(lèi)的寫(xiě)法大家都熟悉,我就不在這里給大家展示了,無(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查詢(xún)的實(shí)現(xiàn)方法
  • ibatis遷移到mybatis3的注意事項(xiàng)
  • 通過(guò)ibatis解決sql注入問(wèn)題
  • Mybatis報(bào)錯(cuò): org.apache.ibatis.exceptions.PersistenceException解決辦法
  • Mybatis與Ibatis的區(qū)別
  • 簡(jiǎn)單了解java ibatis #及$的區(qū)別和用法

標(biāo)簽:南昌 黔南 鹽城 桂林 景德鎮(zhèn) 文山 東莞 宣城

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《ibatis簡(jiǎn)單實(shí)現(xiàn)與配置》,本文關(guān)鍵詞  ibatis,簡(jiǎn)單,實(shí)現(xiàn),與,配置,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《ibatis簡(jiǎn)單實(shí)現(xiàn)與配置》相關(guān)的同類(lèi)信息!
  • 本頁(yè)收集關(guān)于ibatis簡(jiǎn)單實(shí)現(xiàn)與配置的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    欧美阿v视频在线大全_亚洲欧美中文日韩V在线观看_www性欧美日韩欧美91_亚洲欧美日韩久久精品
  • <rt id="w000q"><acronym id="w000q"></acronym></rt>
  • <abbr id="w000q"></abbr>
    <rt id="w000q"></rt>
    首页欧美精品中文字幕| 日本人dh亚洲人ⅹxx| asian性开放少妇pics| 日本韩国一区二区三区视频| 久久精品免视看| 久久99在线观看| 黄色a一级视频| 日韩一区二区三区视频在线| 日韩经典中文字幕一区| 国产极品一区二区| 欧美精品黑人性xxxx| 亚洲国产成人av好男人在线观看| 精品久久久久久无| 久久精品国产成人一区二区三区| 久久久精品人妻无码专区| 日韩一级免费一区| 麻豆一区二区三区| 丰满少妇高潮一区二区| 精品日韩99亚洲| 久久成人精品无人区| 日韩欧美黄色网址| 国产欧美日韩综合| 成人丝袜高跟foot| 在线看国产一区| 亚洲午夜影视影院在线观看| 中国特级黄色片| 欧美猛男gaygay网站| 日韩影院精彩在线| 少妇毛片一区二区三区| 精品日韩在线观看| 国产在线精品免费av| 亚洲女人毛茸茸高潮| 中文字幕在线不卡一区二区三区| 波多野洁衣一区| 欧美日韩大陆一区二区| 丝袜美腿一区二区三区| 国产酒店精品激情| 国产日产欧美一区二区三区| 亚洲国产精品久久人人爱| 亚洲国产欧美视频| 欧美国产精品一区二区| 91啪亚洲精品| 欧美一区二区在线看| 激情综合色播五月| 日韩一区二区三区四区在线| 一区二区三区精品在线| 国产精品无码午夜福利| 亚洲国产精品高清| 91老师片黄在线观看| 日韩精品在线看片z| 国产成人av电影在线观看| 欧美视频一区二区三区在线观看| 首页欧美精品中文字幕| 91大神福利视频| 亚洲综合激情网| 亚洲精品国产一区黑色丝袜| 中文av一区二区| 潘金莲一级淫片aaaaa| 精品美女在线观看| 成人av高清在线| 日韩欧美中文字幕一区| 粉嫩绯色av一区二区在线观看| 欧美日韩高清在线| 国产一区二区导航在线播放| 欧美综合一区二区| 精品一区二区三区在线观看国产 | 国产精品卡一卡二卡三| 精品伦一区二区三区| 久久久久久久综合狠狠综合| 97久久超碰精品国产| 欧美不卡在线视频| 99精品久久99久久久久| 精品精品国产高清a毛片牛牛| 高清不卡在线观看| 欧美一区二区三区白人| 岛国一区二区三区| 精品日韩在线一区| 天堂va欧美va亚洲va老司机| 国产免费久久精品| 免费人成精品欧美精品| 色婷婷国产精品久久包臀| 老司机精品视频线观看86| 日本乱人伦一区| 国产一区二区在线观看视频| 欧美日本乱大交xxxxx| 成人综合婷婷国产精品久久蜜臀| 777午夜精品免费视频| 成人av在线资源| 欧美va亚洲va| 少妇熟女视频一区二区三区| 国产欧美日韩在线| www.免费av| 国产精品久久久久一区| 国产美女免费无遮挡| 一区二区三区四区不卡视频| 日韩国产高清影视| 69av视频在线| 国产一区二区女| 欧美刺激脚交jootjob| 伊人av在线播放| 国产精品国产三级国产aⅴ入口| 亚洲精品国产91| 亚洲成av人片在线观看无码| 色综合激情久久| 国产成人免费在线观看不卡| 精品国产精品一区二区夜夜嗨| 韩国三级hd两男一女| 亚洲精品乱码久久久久久 | 天堂在线一区二区| 欧美日韩精品一区视频| av日韩在线网站| 国产精品久久福利| a级黄色免费视频| 国精品**一区二区三区在线蜜桃| 日韩欧美一级片| 999精品免费视频| 亚洲成人精品一区| 欧美色图免费看| 91免费看视频| 亚洲精品免费在线播放| 91久久精品网| 99精品国产视频| 亚洲日本青草视频在线怡红院| 久久中文免费视频| 成人性生交大片免费看视频在线| 国产人伦精品一区二区| 国产aaaaaaaaa| 国产一区二区三区高清播放| 国产校园另类小说区| 日韩影视一区二区三区| 激情文学综合丁香| 久久色.com| 亚洲a∨无码无在线观看| 狠狠色狠狠色合久久伊人| 久久―日本道色综合久久| 欧美日韩国产黄色| 国产精品一区专区| 国产精品麻豆欧美日韩ww| 精品一区在线观看视频| 成人动漫一区二区三区| 亚洲免费在线观看| 欧美色视频一区| 国产+高潮+白浆+无码| 日韩高清一区二区| 欧美精品一区二区久久婷婷| 国产精品av久久久久久无| 国产精品亚洲午夜一区二区三区 | 最新在线黄色网址| 免费精品视频最新在线| 精品国产电影一区二区| 又色又爽的视频| av不卡在线播放| 亚洲一区av在线| 欧美不卡激情三级在线观看| 免费网站在线高清观看| 高清在线观看日韩| 亚洲精品中文字幕乱码三区| 在线91免费看| 无码少妇精品一区二区免费动态| 国产精品自在在线| 亚洲欧美另类久久久精品| 欧美精品在线视频| 日本高清www| 国产剧情一区在线| 一区二区三区免费| 日韩欧美一区二区在线视频| av资源在线免费观看| 黄色片子免费看| 蜜臀av一区二区| 国产精品人妖ts系列视频| 欧美人狂配大交3d怪物一区| 91激情视频在线观看| 99精品欧美一区二区三区小说| 午夜在线成人av| 久久精品日韩一区二区三区| 欧美性一二三区| 特级西西www444人体聚色| 91在线你懂得| 久久精品72免费观看| 18欧美亚洲精品| 欧美一级午夜免费电影| 一级性生活免费视频| 波多野结衣办公室双飞| 国模少妇一区二区三区| 夜夜精品视频一区二区| 久久婷婷国产综合国色天香| 色拍拍在线精品视频8848| 成年人网站免费在线观看| 成人av电影在线播放| 久久精品国产精品亚洲精品| 亚洲婷婷综合色高清在线| 欧美xxxxxxxxx| 在线观看欧美日本| 日本污视频网站| 性生交大片免费看l| 国产精品原创巨作av| 亚洲不卡一区二区三区| 国产精品视频一区二区三区不卡| 91精品在线免费观看| 五月天丁香激情|