一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術(shù)|正則表達(dá)式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務(wù)器之家 - 編程語言 - Java教程 - 初次體驗MyBatis的注意事項

初次體驗MyBatis的注意事項

2021-09-15 13:27油炸冰可樂 Java教程

今天給大家?guī)淼氖顷P(guān)于MyBatis的相關(guān)知識,文章圍繞著MyBatis的用法展開,文中有非常詳細(xì)的介紹及代碼示例,需要的朋友可以參考下

一、MyBatis的HelloWord

1.根據(jù)xml配置文件(全局配置文件mybatis-config.xml)創(chuàng)建一個SqlSessionFactory對象 有數(shù)據(jù)源一些運行環(huán)境信息

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configuration
 PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
 "http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
   <environments default="development">
      <environment id="development">
         <transactionManager type="JDBC" />
         <dataSource type="POOLED">
            <property name="driver" value="com.mysql.jdbc.Driver" />
            <property name="url" value="jdbc:mysql://localhost:3306/mybatis" />
            <property name="username" value="root" />
            <property name="password" value="123456" />
         </dataSource>
      </environment>
   </environments>
   <!-- 將我們寫好的sql映射文件(EmployeeMapper.xml)一定要注冊到全局配置文件(mybatis-config.xml)中 -->
   <mappers>
      <mapper resource="EmployeeMapper.xml" />
   </mappers>
</configuration>

2.sql映射文件EmployeeMapper.xml;配置了每一個sql,以及sql的封裝規(guī)則等。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
 PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
 "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.atguigu.mybatis.dao.EmployeeMapper">
<!--
namespace:名稱空間;指定為接口的全類名
id:唯一標(biāo)識
resultType:返回值類型
#{id}:從傳遞過來的參數(shù)中取出id值
 
public Employee getEmpById(Integer id);
分離實現(xiàn)與接口
 -->
   <select id="getEmpById" resultType="com.atguigu.mybatis.bean.Employee">
      select id,last_name lastName,email,gender from tbl_employee where id = #{id}
   </select>
</mapper>

3.將sql映射文件注冊在全局配置文件mybatis-config.xml中

?
1
2
3
<mappers>
   <mapper resource="EmployeeMapper.xml" />
</mappers>

4.寫代碼:

1).根據(jù)全局配置文件得到SqlSessionFactory;

?
1
2
3
String resource = "mybatis-config.xml";
InputStream inputStream = Resources.getResourceAsStream(resource);
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);

2).使用sqlSession工廠,獲取到sqlSession對象使用他來執(zhí)行增刪改查,一個sqlSession就是代表和數(shù)據(jù)庫的一次會話,用完關(guān)閉

?
1
SqlSession openSession = sqlSessionFactory.openSession();

3).使用sql的唯一標(biāo)志來告訴MyBatis執(zhí)行哪個sql。sql都是保存在sql映射文件中的

?
1
2
3
4
5
6
7
try {
   Employee employee = openSession.selectOne(
         "com.atguigu.mybatis.dao.EmployeeMapper.getEmpById", 1); // spacename + sqlId
   System.out.println(employee);
} finally {
   openSession.close();
}

二、MyBatis接口式編程

?
1
mybatis:    Mapper.java(接口) ====>  xxMapper.xml(實現(xiàn))

接口式編程的好處在于,能夠?qū)⒐δ芘c實現(xiàn)相分離

1、SqlSession代表和數(shù)據(jù)庫的一次會話;用完必須關(guān)閉;
2、SqlSession和connection一樣它都是非線程安全。每次使用都應(yīng)該去獲取新的對象。
3、mapper.java接口沒有實現(xiàn)類,但是mybatis會為這個接口生成一個代理對象。(將接口和xml進(jìn)行綁定)
EmployeeMapper empMapper = sqlSession.getMapper(EmployeeMapper.class);
4、兩個重要的配置文件:

  • mybatis的全局配置文件:包含數(shù)據(jù)庫連接池信息,事務(wù)管理器信息等…系統(tǒng)運行環(huán)境信息
  • sql映射文件:保存了每一個sql語句的映射信息:將sql抽取出來。

到此這篇關(guān)于初次體驗MyBatis的注意事項的文章就介紹到這了,更多相關(guān)MyBatis的用法內(nèi)容請搜索服務(wù)器之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持服務(wù)器之家!

原文鏈接:https://blog.csdn.net/Wang_Pro/article/details/118110119

延伸 · 閱讀

精彩推薦
  • Java教程xml與Java對象的轉(zhuǎn)換詳解

    xml與Java對象的轉(zhuǎn)換詳解

    這篇文章主要介紹了xml與Java對象的轉(zhuǎn)換詳解的相關(guān)資料,需要的朋友可以參考下...

    Java教程網(wǎng)2942020-09-17
  • Java教程小米推送Java代碼

    小米推送Java代碼

    今天小編就為大家分享一篇關(guān)于小米推送Java代碼,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧...

    富貴穩(wěn)中求8032021-07-12
  • Java教程Java實現(xiàn)搶紅包功能

    Java實現(xiàn)搶紅包功能

    這篇文章主要為大家詳細(xì)介紹了Java實現(xiàn)搶紅包功能,采用多線程模擬多人同時搶紅包,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙...

    littleschemer13532021-05-16
  • Java教程Java8中Stream使用的一個注意事項

    Java8中Stream使用的一個注意事項

    最近在工作中發(fā)現(xiàn)了對于集合操作轉(zhuǎn)換的神器,java8新特性 stream,但在使用中遇到了一個非常重要的注意點,所以這篇文章主要給大家介紹了關(guān)于Java8中S...

    阿杜7472021-02-04
  • Java教程Java使用SAX解析xml的示例

    Java使用SAX解析xml的示例

    這篇文章主要介紹了Java使用SAX解析xml的示例,幫助大家更好的理解和學(xué)習(xí)使用Java,感興趣的朋友可以了解下...

    大行者10067412021-08-30
  • Java教程Java BufferWriter寫文件寫不進(jìn)去或缺失數(shù)據(jù)的解決

    Java BufferWriter寫文件寫不進(jìn)去或缺失數(shù)據(jù)的解決

    這篇文章主要介紹了Java BufferWriter寫文件寫不進(jìn)去或缺失數(shù)據(jù)的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望...

    spcoder14552021-10-18
  • Java教程升級IDEA后Lombok不能使用的解決方法

    升級IDEA后Lombok不能使用的解決方法

    最近看到提示IDEA提示升級,尋思已經(jīng)有好久沒有升過級了。升級完畢重啟之后,突然發(fā)現(xiàn)好多錯誤,本文就來介紹一下如何解決,感興趣的可以了解一下...

    程序猿DD9332021-10-08
  • Java教程20個非常實用的Java程序代碼片段

    20個非常實用的Java程序代碼片段

    這篇文章主要為大家分享了20個非常實用的Java程序片段,對java開發(fā)項目有所幫助,感興趣的小伙伴們可以參考一下 ...

    lijiao5352020-04-06
主站蜘蛛池模板: 国产精品亚洲综合久久 | 草大逼 | 国产成人91高清精品免费 | 久9视频这里只有精品123 | 欧美一区二区三区在线观看不卡 | 91麻豆在线观看 | 冰雪奇缘1完整版免费观看 变形金刚第一部 | 四虎成人网 | 天堂网www中文天堂在线 | 婷婷在线综合 | 黄瓜视频黄版 | 精品视频国产 | 成人高清网站 | 日本69视频在线观看 | 美女漫画网| 亚洲精品www久久久久久 | 手机看片国产免费久久网 | 女bbbbxxxx视频 | 久久AV喷吹AV高潮欧美 | 日本视频高清 | caoporen97免费公开视频 | 扒开老师两片湿漉的肉 | 狠狠色狠狠色综合曰曰 | 精品日韩一区二区三区 | 91久久福利国产成人精品 | h卡通第一页| 婷婷色在线 | 大胸纲手被羞羞漫画网站 | 麻豆视频免费在线观看 | 欧美二区视频 | 美女脱了内裤打开腿让你桶爽 | 91精品免费国产高清在线 | 亚瑟天堂久久一区二区影院 | 青草热久精品视频在线观看 | 边摸边吃奶边做爽视频免费 | 美女18隐私羞羞视频网站 | 午夜在线a亚洲v天堂网2019 | 奇米影视先锋 | 国产特黄a级在线视频 | 污斗罗大陆 | 欧美日韩国产在线人成dvd |