溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

MyBatis入門介紹(超簡(jiǎn)單)

發(fā)布時(shí)間:2020-08-30 12:38:00 來(lái)源:腳本之家 閱讀:214 作者:mrr 欄目:編程語(yǔ)言

MyBatis 簡(jiǎn)介

MyBatis的前身叫iBatis,本是apache的一個(gè)開源項(xiàng)目, 2010年這個(gè)項(xiàng)目由apache software foundation 遷移到了google code,并且改名為MyBatis。MyBatis是支持普通SQL查詢,存儲(chǔ)過(guò)程和高級(jí)映射的優(yōu)秀持久層框架。MyBatis消除了幾乎所有的JDBC代碼和參數(shù)的手工設(shè)置以及結(jié)果集的檢索。MyBatis使用簡(jiǎn)單的XML或注解用于配置和原始映射,將接口和Java的POJOs(Plan Old Java Objects,普通的Java對(duì)象)映射成數(shù)據(jù)庫(kù)中的記錄。

首先介紹一下Mybatis是什么?mybatis是Java的持久層框架, JAVA操作數(shù)據(jù)庫(kù)是通過(guò)jdbc來(lái)操作的,而mybatis是對(duì)jdbc的封裝。

  使用mybatis之后,開發(fā)者只需要關(guān)注sql語(yǔ)句本身,而不必花時(shí)間去注冊(cè)驅(qū)動(dòng)、創(chuàng)建connection、statement、手動(dòng)設(shè)置參數(shù),結(jié)果集檢索等jdbc繁瑣的代碼。

  mybatis基本過(guò)程:Mybatis通過(guò)xml或注解的方式將要執(zhí)行的各種statement(statement、preparedStatemnt、CallableStatement)配置起來(lái),并通過(guò)java對(duì)象和statement中的sql進(jìn)行映射生成最終執(zhí)行的sql語(yǔ)句,最后由mybatis框架執(zhí)行sql并將結(jié)果映射成java對(duì)象并返回。

  下面通過(guò)一個(gè)根據(jù)用戶id查詢用戶信息來(lái)學(xué)習(xí)mybatis:

     先介紹一下mybatis的兩種主要的配置文件:

        SqlMapConfig.xml(mybatis全局配置文件,名稱不固定,用來(lái)配置運(yùn)行環(huán)境(數(shù)據(jù)源、事務(wù))

        類名+mapper.xml 主要用來(lái)配置sql語(yǔ)句

  一、首先我們需要在mybatis的全局配置文件(SqlMapConfig.xml)中配置jdbc連接池,和加載mapper.xml.

當(dāng)系統(tǒng)啟動(dòng)時(shí),會(huì)加載這個(gè)全局配置文件,然后通過(guò)全局配置文件加載到mapper.xml文件。mapper.xml文件中配置了sql語(yǔ)句。

  二、編寫SqlSessionFactory。mybatis的核心就是這個(gè)SqlSessionFactory。通過(guò)這個(gè)SqlSessionFactory將配置文件以參數(shù)的形式傳入之后,創(chuàng)建了一個(gè)會(huì)話。

然后通過(guò)sqlsession來(lái)操作數(shù)據(jù)庫(kù),進(jìn)行增刪改查。

  下面來(lái)對(duì)第一步和第二步分別做個(gè)細(xì)致的分析。首先貼上代碼:

sqlMapperConfig.xml

<environments default="development">
    <environment id="development">
    <!-- 使用jdbc事務(wù)管理-->
      <transactionManager type="JDBC" />
    <!-- 數(shù)據(jù)庫(kù)連接池-->
      <dataSource type="POOLED">
        <property name="driver" value="${jdbc.driver}"/>
        <property name="url" value="${jdbc.url}"/>
        <property name="username" value="${jdbc.username}"/>
        <property name="password" value="${jdbc.password}"/>
      </dataSource>
    </environment>
  </environments>
  <mappers>
    <!-- 通過(guò)resource引用mapper的映射文件 -->
    <mapper resource="sqlmap/User.xml" />
  </mappers>

 通過(guò)這個(gè)配置文件可以看出總的配置文件是配置一些主要信息和加載別的配置文件。當(dāng)mybatis和Spring整合之后,environment就會(huì)被廢除。同時(shí),這種全局配置文件只會(huì)有一個(gè)。而 "表名+mapper.xml"這種配置文件則會(huì)有很多。

下面來(lái)分析 "表名+mapper.xml"

<!-- namespace命名空間,為了對(duì)sql語(yǔ)句進(jìn)行隔離,方便管理 ,mapper開發(fā)dao方式,使用namespace有特殊作用
mapper代理開發(fā)時(shí)將namespace指定為mapper接口的全限定名
 -->
<mapper namespace="test">
<!-- 在mapper.xml文件中配置很多的sql語(yǔ)句,執(zhí)行每個(gè)sql語(yǔ)句時(shí),封裝為MappedStatement對(duì)象
mapper.xml以statement為單位管理sql語(yǔ)句
 -->
  <!-- 根據(jù)id查詢用戶信息 -->
  <!-- 
    id:唯一標(biāo)識(shí) 一個(gè)statement
    #{}:表示 一個(gè)占位符,如果#{}中傳入簡(jiǎn)單類型的參數(shù),#{}中的名稱隨意
    parameterType:輸入 參數(shù)的類型,通過(guò)#{}接收parameterType輸入 的參數(shù)
    resultType:輸出結(jié)果 類型,不管返回是多條還是單條,指定單條記錄映射的pojo類型
   -->
  <select id="findUserById" parameterType="int" resultType="cn.itcast.mybatis.po.User">
    SELECT * FROM USER WHERE id= #{id}
  </select>

    從代碼中可以看出這個(gè)配置文件是用來(lái)配置sql語(yǔ)句的。但是應(yīng)當(dāng)注意,最上面的namespace的注釋,namespace命名空間,為了對(duì)sql語(yǔ)句進(jìn)行隔離,方便管理 ,mapper開發(fā)dao方式,使用namespace有特殊作用,mapper代理開發(fā)時(shí)將namespace指定為mapper接口的全限定名。

在后面的SQLSessionFactory類中就能看出其作用了。

  這個(gè)配置文件中的每個(gè)sql語(yǔ)句,其實(shí)都是jdbc中的statement,這樣的話,其實(shí)mybatis內(nèi)部也是在操作statement。

  這里的<select>標(biāo)簽里面?zhèn)鲄⒂玫降氖?{},而我們要用模糊查詢的時(shí)候是不能用這個(gè)直接加上%的。

  但是有一種方法就是 使用${}接收參數(shù)!如下:

<!-- 根據(jù)用戶名稱查詢用戶信息,可能返回多條
  ${}:表示sql的拼接,通過(guò)${}接收參數(shù),將參數(shù)的內(nèi)容不加任何修飾拼接在sql中。
   -->
  <select id="findUserByName" parameterType="java.lang.String" resultType="cn.itcast.mybatis.po.User">
    select * from user where username like '%${value}%'
  </select>

但是上面這種方法是不加任何修飾的拼接在sql中的,也就是不能防止sql注入,所以這種方法也不能應(yīng)用到實(shí)際項(xiàng)目中!

所以,我在百度上搜到了另一種方式來(lái)進(jìn)行模糊查詢,不知道有沒(méi)有什么bug,但是我測(cè)試是可以用的。

<!-- 根據(jù)用戶名模糊查詢查詢出員工的信息 -->
  <select id="search" resultType="Employee">
    SELECT 
      <include refid="allColumns"/>
    FROM employee a where a.name like concat(concat('%',#{name}),'%')
  </select>

下面來(lái)看看sqlsessionFactory會(huì)話工廠的代碼:

public class MybatisFirst {
  // 會(huì)話工廠
  private SqlSessionFactory sqlSessionFactory;
  // 創(chuàng)建工廠
  @Before
  public void init() throws IOException {
    // 配置文件(SqlMapConfig.xml)
    String resource = "SqlMapConfig.xml";
    // 加載配置文件到輸入 流
    InputStream inputStream = Resources.getResourceAsStream(resource);
    // 創(chuàng)建會(huì)話工廠
    sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
  }
  // 測(cè)試根據(jù)id查詢用戶(得到單條記錄)
  @Test
  public void testFindUserById() {
    // 通過(guò)sqlSessionFactory創(chuàng)建sqlSession
    SqlSession sqlSession = sqlSessionFactory.openSession();
    // 通過(guò)sqlSession操作數(shù)據(jù)庫(kù)
    // 第一個(gè)參數(shù):statement的位置,等于namespace+statement的id
    // 第二個(gè)參數(shù):傳入的參數(shù)
    User user = null;
    try {
      user = sqlSession.selectOne("test.findUserById", 2);
    } catch (Exception e) {
      e.printStackTrace();
    } finally {
      // 關(guān)閉sqlSession
      sqlSession.close();
    }
    System.out.println(user);
  }

會(huì)話工廠的代碼很簡(jiǎn)單,就是:家在配置文件、創(chuàng)建會(huì)話工廠、通過(guò)會(huì)話操作數(shù)據(jù)庫(kù)、關(guān)閉會(huì)話:

但是請(qǐng)注意第35行的參數(shù)。就是我們前面提到的namespace的test,是為了隔離sql而寫的,這里體現(xiàn)的它的作用!

還有就是selectOne這兩個(gè)參數(shù)各自的意義:第一個(gè)參數(shù)就是我們所說(shuō)的“表名+mappe.xml”中定義的sql語(yǔ)句,其實(shí)就是一個(gè)statement.第二個(gè)參數(shù)就是sql語(yǔ)句需要傳入的參數(shù),也就是id

總結(jié)

以上所述是小編給大家介紹的MyBatis入門介紹,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)億速云網(wǎng)站的支持!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI