欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

初次體驗(yàn)MyBatis的注意事項(xiàng)

 更新時(shí)間:2021年06月25日 14:20:10   作者:油炸冰可樂(lè)  
今天給大家?guī)?lái)的是關(guān)于MyBatis的相關(guān)知識(shí),文章圍繞著MyBatis的用法展開(kāi),文中有非常詳細(xì)的介紹及代碼示例,需要的朋友可以參考下

一、MyBatis的HelloWord

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

<?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>
   <!-- 將我們寫(xiě)好的sql映射文件(EmployeeMapper.xml)一定要注冊(cè)到全局配置文件(mybatis-config.xml)中 -->
   <mappers>
      <mapper resource="EmployeeMapper.xml" />
   </mappers>
</configuration>

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

<?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:名稱(chēng)空間;指定為接口的全類(lèi)名
id:唯一標(biāo)識(shí)
resultType:返回值類(lèi)型
#{id}:從傳遞過(guò)來(lái)的參數(shù)中取出id值

public Employee getEmpById(Integer id);
分離實(shí)現(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映射文件注冊(cè)在全局配置文件mybatis-config.xml中

<mappers>
   <mapper resource="EmployeeMapper.xml" />
</mappers>

4.寫(xiě)代碼:

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

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

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

SqlSession openSession = sqlSessionFactory.openSession();

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

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

二、MyBatis接口式編程

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

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

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

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

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

相關(guān)文章

  • Java8 Supplier接口和Consumer接口原理解析

    Java8 Supplier接口和Consumer接口原理解析

    這篇文章主要介紹了Java8 Supplier接口和Consumer接口原理解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-04-04
  • Java Socket上的Read操作阻塞問(wèn)題詳解

    Java Socket上的Read操作阻塞問(wèn)題詳解

    這篇文章主要介紹了Java Socket上的Read操作阻塞問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-10-10
  • java  中MyBatis注解映射的實(shí)例詳解

    java 中MyBatis注解映射的實(shí)例詳解

    這篇文章主要介紹了java 中MyBatis注解映射的實(shí)例詳解的相關(guān)資料,這里提供實(shí)例幫助大家理解這部分內(nèi)容,需要的朋友可以參考下
    2017-09-09
  • springboot使用Logback把日志輸出到控制臺(tái)或輸出到文件

    springboot使用Logback把日志輸出到控制臺(tái)或輸出到文件

    這篇文章給大家介紹springboot項(xiàng)目使用日志工具Logback把日志不僅輸出到控制臺(tái),也可以輸出到文件的操作方法,本文通過(guò)實(shí)例圖文相結(jié)合給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧
    2020-10-10
  • Jedis對(duì)redis的五大類(lèi)型操作代碼詳解

    Jedis對(duì)redis的五大類(lèi)型操作代碼詳解

    這篇文章主要介紹了Jedis對(duì)redis的五大操作代碼詳解,分別是字符串、列表、散列、集合、有序集合,具有一定參考價(jià)值,需要的朋友可以了解下。
    2017-11-11
  • Mybatis添加Ehcache支持的方法

    Mybatis添加Ehcache支持的方法

    mybatis添加ehcache支持非常簡(jiǎn)單,只主要在sql映射文件中添加一行代碼就可以實(shí)現(xiàn),糾結(jié)是什么代碼呢,這么神奇,帶著這樣問(wèn)題一起通過(guò)本文學(xué)習(xí)吧
    2016-08-08
  • SpringBoot2.0集成WebSocket實(shí)現(xiàn)后臺(tái)向前端推送信息

    SpringBoot2.0集成WebSocket實(shí)現(xiàn)后臺(tái)向前端推送信息

    這篇文章主要介紹了SpringBoot2.0集成WebSocket實(shí)現(xiàn)后臺(tái)向前端推送信息,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-01-01
  • Java中的FutureTask實(shí)現(xiàn)異步任務(wù)代碼實(shí)例

    Java中的FutureTask實(shí)現(xiàn)異步任務(wù)代碼實(shí)例

    這篇文章主要介紹了Java中的FutureTask實(shí)現(xiàn)異步任務(wù)代碼實(shí)例,普通的線程執(zhí)行是無(wú)法獲取到執(zhí)行結(jié)果的,FutureTask?間接實(shí)現(xiàn)了?Runnable?和?Future?接口,可以得到子線程耗時(shí)操作的執(zhí)行結(jié)果,AsyncTask?異步任務(wù)就是使用了該機(jī)制,需要的朋友可以參考下
    2024-01-01
  • Java配置JDK開(kāi)發(fā)環(huán)境及環(huán)境變量

    Java配置JDK開(kāi)發(fā)環(huán)境及環(huán)境變量

    這篇文章主要為大家詳細(xì)介紹了Java配置JDK開(kāi)發(fā)環(huán)境及環(huán)境變量,文中安裝步驟介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2016-09-09
  • IDEA2023 配置使用Docker的詳細(xì)教程

    IDEA2023 配置使用Docker的詳細(xì)教程

    這篇文章主要介紹了IDEA2023 配置使用Docker的詳細(xì)教程,本文通過(guò)圖文并茂的形式給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-07-07

最新評(píng)論