溫馨提示×

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

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

怎么快速配置一個(gè)Mybatis環(huán)境

發(fā)布時(shí)間:2021-01-18 14:29:33 來源:億速云 閱讀:185 作者:Leah 欄目:開發(fā)技術(shù)

這篇文章給大家介紹怎么快速配置一個(gè)Mybatis環(huán)境,內(nèi)容非常詳細(xì),感興趣的小伙伴們可以參考借鑒,希望對(duì)大家能有所幫助。

一、mybatis環(huán)境配置

1.通過maven的pom.xml文件引入mybatis需要的包

在其<dependencies></dependencies>標(biāo)簽中添加如下代碼

 <dependency>
      <groupId>org.mybatis</groupId>
      <artifactId>mybatis</artifactId>
      <version>3.5.1</version>
 </dependency>

2.在src/main/resources下新建mybatis-config.xml文件

并進(jìn)行xml文件和config的dtd文件的聲明

  <?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">

3.在mybatis-config.xml文件中的<configuration></configuration>中對(duì)數(shù)據(jù)庫進(jìn)行配置

<configuration>
  <settings>
<!--    開啟駝峰命名轉(zhuǎn)換,若底層數(shù)據(jù)庫表項(xiàng)為goods_ID,實(shí)體類為goodsId ,則自動(dòng)轉(zhuǎn)換-->
    <setting name="mapUnderscoreToCamelCase" value="true"/>
  </settings>
  <!-- 設(shè)置默認(rèn)指向的數(shù)據(jù)庫 -->
  <environments default="dev">
    <environment id="dev">
      <!-- 采用JDBC方式對(duì)數(shù)據(jù)庫事務(wù)進(jìn)行commit/rollback -->
      <transactionManager type="JDBC"></transactionManager>
      <!-- 采用連接池的方式管理數(shù)據(jù)庫連接  -->
      <dataSource type="POOLED">
        <property name="driver" value="com.mysql.jdbc.Driver"/>
        <property name="url" value="jdbc:mysql://localhost:3306/babytun?useUnicode=true&amp;characterEncoding=UTF-8"/>
        <property name="username" value="root"/>
        <property name="password" value="123456"/>
      </dataSource>
    </environment>
  </environments>
</configuration>

4.通過SqlSessionFactory構(gòu)建SqlSession會(huì)話實(shí)例

每個(gè)基于 MyBatis 的應(yīng)用都是以一個(gè) SqlSessionFactory 的實(shí)例為核心的。SqlSessionFactory 的實(shí)例可以通過 SqlSessionFactoryBuilder 獲得。而 SqlSessionFactoryBuilder 則可以從 XML 配置文件或一個(gè)預(yù)先配置的 Configuration 實(shí)例來構(gòu)建出 SqlSessionFactory 實(shí)例。

從 XML 文件中構(gòu)建 SqlSessionFactory 的實(shí)例非常簡(jiǎn)單,建議使用類路徑下的資源文件進(jìn)行配置。 但也可以使用任意的輸入流(InputStream)實(shí)例,比如用文件路徑字符串或 file:// URL 構(gòu)造的輸入流。MyBatis 包含一個(gè)名叫 Resources 的工具類,它包含一些實(shí)用方法,使得從類路徑或其它位置加載資源文件更加容易。

通常SqlSession是全局唯一的,通過MybatisUtils工具類減少重復(fù)代碼

public class MybatisUtils {
  //利用static靜態(tài) 屬于類而不屬于對(duì)象 , 保證全局唯一
  private static SqlSessionFactory sqlSessionFactory = null ;
  //利用靜態(tài)塊在初始化類時(shí)實(shí)力話SqlSessionFactory
  static {
    Reader reader = null;
    try {
      reader = Resources.getResourceAsReader("mybatis-config.xml");
      sqlSessionFactory = new SqlSessionFactoryBuilder().build(reader) ;
    } catch (IOException e) {
      e.printStackTrace();
      //初始化過程中出現(xiàn)的異常
      throw new ExceptionInInitializerError(e) ;
    }
  }

  /**
   * 創(chuàng)建一個(gè)新的sqlsession對(duì)象
   * @return sqlsession對(duì)象
   * */

  public static SqlSession openSession(){
    return sqlSessionFactory.openSession() ;
  }

  public static void closeSession(SqlSession sqlSession){
    if(sqlSession != null ){
      sqlSession.close();
    }
  }

}

5.通過SqlSession對(duì)數(shù)據(jù)庫進(jìn)行操作

在entity包下創(chuàng)建要操作的數(shù)據(jù)庫表對(duì)應(yīng)的實(shí)體類(必須使用駝峰命名和設(shè)置get和set方法),同時(shí)在resources目錄下創(chuàng)建mappers目錄,在mappers目錄下創(chuàng)建與該實(shí)體類同名的xml文件,在對(duì)其進(jìn)行xml聲明和mapperdtd文件聲明(注意與mybatis-config.xml的dtd文件聲明的區(qū)別)

<?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">

然后在mybatis-config.xml文件引入該實(shí)體與數(shù)據(jù)庫的映射。即在其<mappers></mappers>標(biāo)簽中添加映射xml文件路徑

 <mappers>
    <mapper resource="mappers/goods.xml" />
    <mapper resource="mappers/goods_detail.xml" />
 </mappers>

當(dāng)數(shù)據(jù)庫列字段名為多單詞且用"_"拼接時(shí),還需在其<configuration></configuration>標(biāo)簽中開啟駝峰命名轉(zhuǎn)換,使Mybatis自動(dòng)完成映射。

 <settings>
<!--    開啟駝峰命名轉(zhuǎn)換,若底層數(shù)據(jù)庫表項(xiàng)為goods_ID,實(shí)體類為goodsId ,則自動(dòng)轉(zhuǎn)換-->
    <setting name="mapUnderscoreToCamelCase" value="true"/>
 </settings>

到此為止,mybatis需要的配置就已全部完成。

運(yùn)行程序測(cè)試結(jié)果

在 src 源碼目錄下建立 一個(gè)類叫作:HelloWord, 來運(yùn)行測(cè)試配置環(huán)境是否成功,具體代碼如下示:

import java.io.Reader;

import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;

import com.yiibai.mybatis.models.*;

/**
 * 
 * @author yiibai
 * @copyright //www.jb51.net
 * @date 2015/09/22
 */
public class HelloWord {
 private static SqlSessionFactory sqlSessionFactory;
 private static Reader reader;

 static {
 try {
  reader = Resources.getResourceAsReader("config/Configure.xml");
  sqlSessionFactory = new SqlSessionFactoryBuilder().build(reader);
 } catch (Exception e) {
  e.printStackTrace();
 }
 }
 public static SqlSessionFactory getSession() {
 return sqlSessionFactory;
 }
 /**
 * @param args
 */
 public static void main(String[] args) {
 // TODO Auto-generated method stub
 SqlSession session = sqlSessionFactory.openSession();
 try {
  User user = (User) session.selectOne(
   "com.yiibai.mybatis.models.UserMapper.GetUserByID", 1);
  if(user!=null){
  String userInfo = "名字:"+user.getName()+", 所屬部門:"+user.getDept()+", 主頁:"+user.getWebsite();
  System.out.println(userInfo);
  }
 } finally {
  session.close();
 }
 }
}

關(guān)于怎么快速配置一個(gè)Mybatis環(huán)境就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,可以學(xué)到更多知識(shí)。如果覺得文章不錯(cuò),可以把它分享出去讓更多的人看到。

向AI問一下細(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