亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Mybatis環(huán)境配置及測(cè)試詳解

 更新時(shí)間:2021年01月18日 10:29:27   作者:Pumpkin  
這篇文章主要介紹了Mybatis環(huán)境配置及測(cè)試詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧

mybatis 3 | 參考文檔

MyBatis 是一款優(yōu)秀的持久層框架,它支持自定義 SQL、存儲(chǔ)過(guò)程以及高級(jí)映射。MyBatis 免除了幾乎所有的 JDBC 代碼以及設(shè)置參數(shù)和獲取結(jié)果集的工作。

MyBatis 可以通過(guò)簡(jiǎn)單的 XML 或注解來(lái)配置和映射原始類(lèi)型、接口和 Java POJO(Plain Old Java Objects,普通老式 Java 對(duì)象)為數(shù)據(jù)庫(kù)中的記錄。

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

1.通過(guò)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ù)庫(kù)進(jìn)行配置

<configuration>
  <settings>
<!--    開(kāi)啟駝峰命名轉(zhuǎn)換,若底層數(shù)據(jù)庫(kù)表項(xiàng)為goods_ID,實(shí)體類(lèi)為goodsId ,則自動(dòng)轉(zhuǎn)換-->
    <setting name="mapUnderscoreToCamelCase" value="true"/>
  </settings>
  <!-- 設(shè)置默認(rèn)指向的數(shù)據(jù)庫(kù) -->
  <environments default="dev">
    <environment id="dev">
      <!-- 采用JDBC方式對(duì)數(shù)據(jù)庫(kù)事務(wù)進(jìn)行commit/rollback -->
      <transactionManager type="JDBC"></transactionManager>
      <!-- 采用連接池的方式管理數(shù)據(jù)庫(kù)連接  -->
      <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.通過(guò)SqlSessionFactory構(gòu)建SqlSession會(huì)話實(shí)例

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

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

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

public class MybatisUtils {
  //利用static靜態(tài) 屬于類(lèi)而不屬于對(duì)象 , 保證全局唯一
  private static SqlSessionFactory sqlSessionFactory = null ;
  //利用靜態(tài)塊在初始化類(lè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();
      //初始化過(guò)程中出現(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.通過(guò)SqlSession對(duì)數(shù)據(jù)庫(kù)進(jìn)行操作

在entity包下創(chuàng)建要操作的數(shù)據(jù)庫(kù)表對(duì)應(yīng)的實(shí)體類(lèi)(必須使用駝峰命名和設(shè)置get和set方法),同時(shí)在resources目錄下創(chuàng)建mappers目錄,在mappers目錄下創(chuàng)建與該實(shí)體類(lèi)同名的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ù)庫(kù)的映射。即在其<mappers></mappers>標(biāo)簽中添加映射xml文件路徑

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

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

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

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

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

在 src 源碼目錄下建立 一個(gè)類(lèi)叫作:HelloWord, 來(lái)運(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 //chabaoo.cn
 * @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()+", 所屬部門(mén):"+user.getDept()+", 主頁(yè):"+user.getWebsite();
  System.out.println(userInfo);
  }
 } finally {
  session.close();
 }
 }
}

現(xiàn)在運(yùn)行這個(gè)程序,不是得到查詢(xún)結(jié)果了?正確的輸出結(jié)果應(yīng)該如下:

名字:yiibai, 所屬部門(mén):Tech, 主頁(yè)://chabaoo.cn

到此這篇關(guān)于Mybatis環(huán)境配置及測(cè)試詳解的文章就介紹到這了,更多相關(guān)Mybatis環(huán)境配置內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Java生成UUID的常用方式示例代碼

    Java生成UUID的常用方式示例代碼

    UUID保證對(duì)在同一時(shí)空中的所有機(jī)器都是唯一的,通常平臺(tái)會(huì)提供生成的API,按照開(kāi)放軟件基金會(huì)(OSF)制定的標(biāo)準(zhǔn)計(jì)算,用到了以太網(wǎng)卡地址、納秒級(jí)時(shí)間、芯片ID碼和許多可能的數(shù)字,下面這篇文章主要給大家介紹了關(guān)于Java生成UUID的常用方式,需要的朋友可以參考下
    2023-05-05
  • java中ArrayList與LinkedList對(duì)比詳情

    java中ArrayList與LinkedList對(duì)比詳情

    這篇文章主要通過(guò)實(shí)例對(duì)Java中ArrayList與LinkedList進(jìn)行了對(duì)比,需要的朋友可以參考下
    2017-04-04
  • 使用Java和高德地圖API將經(jīng)緯度轉(zhuǎn)換為地理位置信息的步驟

    使用Java和高德地圖API將經(jīng)緯度轉(zhuǎn)換為地理位置信息的步驟

    這篇文章詳細(xì)介紹了如何將GPS坐標(biāo)轉(zhuǎn)換為人類(lèi)可讀的地理位置,介紹了環(huán)境準(zhǔn)備、代碼實(shí)現(xiàn)、異常處理及優(yōu)化步驟,首先創(chuàng)建LocationFinder類(lèi),實(shí)現(xiàn)getLocationFromCoordinates方法,利用高德逆地理編碼API轉(zhuǎn)換坐標(biāo),文中通過(guò)代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2024-09-09
  • Spring Security  整體架構(gòu)操作流程

    Spring Security  整體架構(gòu)操作流程

    這篇文章主要介紹了Spring Security  整體架構(gòu)操作流程,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧
    2024-07-07
  • Jmeter安裝及配置教程詳解

    Jmeter安裝及配置教程詳解

    很多朋友私信小編Jmeter安裝及配置教程能出一期教程嗎?正巧趕上疫情,不是太忙,下面小編把Jmeter安裝及配置教程分享到腳本之家平臺(tái),感興趣的朋友跟隨小編一起看看吧
    2021-12-12
  • Java SpringMVC數(shù)據(jù)響應(yīng)超詳細(xì)講解

    Java SpringMVC數(shù)據(jù)響應(yīng)超詳細(xì)講解

    Spring?MVC?是?Spring?提供的一個(gè)基于?MVC?設(shè)計(jì)模式的輕量級(jí)?Web?開(kāi)發(fā)框架,本質(zhì)上相當(dāng)于?Servlet,Spring?MVC?角色劃分清晰,分工明細(xì),本章來(lái)講解SpringMVC數(shù)據(jù)響應(yīng)
    2022-04-04
  • Java流程控制break和continue

    Java流程控制break和continue

    這篇文章主要介紹了Java流程控制break和continue,下面文章圍繞break和continue的相關(guān)資料展開(kāi)詳細(xì)內(nèi)容,具有一定的參考價(jià)值,需要的小伙伴可以參考一下
    2021-12-12
  • Java如何實(shí)現(xiàn)List自定義排序

    Java如何實(shí)現(xiàn)List自定義排序

    這篇文章主要介紹了Java如何實(shí)現(xiàn)List自定義排序,幫助大家更好的理解和使用Java,感興趣的朋友可以了解下
    2020-09-09
  • Eclipse在線安裝hibernate插件

    Eclipse在線安裝hibernate插件

    這篇文章主要介紹了Eclipse在線安裝hibernate插件,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2019-04-04
  • String split方法實(shí)現(xiàn)過(guò)程圖解

    String split方法實(shí)現(xiàn)過(guò)程圖解

    這篇文章主要介紹了String split方法實(shí)現(xiàn)過(guò)程圖解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-11-11

最新評(píng)論