亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術文章
文章詳情頁

Mybatis環境配置及測試詳解

瀏覽:20日期:2023-10-20 12:08:26

mybatis 3 | 參考文檔

MyBatis 是一款優秀的持久層框架,它支持自定義 SQL、存儲過程以及高級映射。MyBatis 免除了幾乎所有的 JDBC 代碼以及設置參數和獲取結果集的工作。

MyBatis 可以通過簡單的 XML 或注解來配置和映射原始類型、接口和 Java POJO(Plain Old Java Objects,普通老式 Java 對象)為數據庫中的記錄。

一、mybatis環境配置

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

在其<dependencies></dependencies>標簽中添加如下代碼

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

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

并進行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>中對數據庫進行配置

<configuration> <settings><!-- 開啟駝峰命名轉換,若底層數據庫表項為goods_ID,實體類為goodsId ,則自動轉換--> <setting name='mapUnderscoreToCamelCase' value='true'/> </settings> <!-- 設置默認指向的數據庫 --> <environments default='dev'> <environment id='dev'> <!-- 采用JDBC方式對數據庫事務進行commit/rollback --> <transactionManager type='JDBC'></transactionManager> <!-- 采用連接池的方式管理數據庫連接 --> <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構建SqlSession會話實例

每個基于 MyBatis 的應用都是以一個 SqlSessionFactory 的實例為核心的。SqlSessionFactory 的實例可以通過 SqlSessionFactoryBuilder 獲得。而 SqlSessionFactoryBuilder 則可以從 XML 配置文件或一個預先配置的 Configuration 實例來構建出 SqlSessionFactory 實例。

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

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

public class MybatisUtils { //利用static靜態 屬于類而不屬于對象 , 保證全局唯一 private static SqlSessionFactory sqlSessionFactory = null ; //利用靜態塊在初始化類時實力話SqlSessionFactory static { Reader reader = null; try { reader = Resources.getResourceAsReader('mybatis-config.xml'); sqlSessionFactory = new SqlSessionFactoryBuilder().build(reader) ; } catch (IOException e) { e.printStackTrace(); //初始化過程中出現的異常 throw new ExceptionInInitializerError(e) ; } } /** * 創建一個新的sqlsession對象 * @return sqlsession對象 * */ public static SqlSession openSession(){ return sqlSessionFactory.openSession() ; } public static void closeSession(SqlSession sqlSession){ if(sqlSession != null ){ sqlSession.close(); } }}5.通過SqlSession對數據庫進行操作

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

<?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文件引入該實體與數據庫的映射。即在其<mappers></mappers>標簽中添加映射xml文件路徑

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

當數據庫列字段名為多單詞且用'_'拼接時,還需在其<configuration></configuration>標簽中開啟駝峰命名轉換,使Mybatis自動完成映射。

<settings><!-- 開啟駝峰命名轉換,若底層數據庫表項為goods_ID,實體類為goodsId ,則自動轉換--> <setting name='mapUnderscoreToCamelCase' value='true'/> </settings>

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

運行程序測試結果

在 src 源碼目錄下建立 一個類叫作:HelloWord, 來運行測試配置環境是否成功,具體代碼如下示:

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(); } }}

現在運行這個程序,不是得到查詢結果了?正確的輸出結果應該如下:

名字:yiibai, 所屬部門:Tech, 主頁://www.jb51.net

到此這篇關于Mybatis環境配置及測試詳解的文章就介紹到這了,更多相關Mybatis環境配置內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Mybatis 數據庫
相關文章:
主站蜘蛛池模板: 午夜国产精品影院在线观看 | 成人无遮挡免费网站视频在线观看 | 激情亚洲视频 | 日韩中文有码高清 | 欧美黄色大片视频 | 九九精品国产兔费观看久久 | 久久受www免费人成看片 | 欧美综合视频在线 | 麻豆免费视频网站入口 | 亚洲精品日韩精品一区 | 一级毛片a女人刺激视频免费 | 毛片视频网址 | 午夜伦情电午夜伦情影院 | 狠狠色丁香婷婷综合激情 | 99精品网 | 国产精品亚洲精品日韩已满 | 欧美日韩亚洲精品国产色 | 欧美一级毛片日本 | 国产另类图片 | 大陆三级特黄在线播放 | 久久99精品久久久久久久不卡 | 日韩亚洲精品不卡在线 | 欧美日韩一卡 | 丝袜美女被出水视频一区 | 日本三级黄色 | 国产精品v欧美精品v日本精 | 免费国产最新进精品视频 | 91综合视频| 黄色短视频免费 | 大乳女人做受视频免费观看 | 国产精品一区二区免费 | 狠狠色噜噜狠狠狠狠狠色综合久久 | 亚洲和欧美毛片久久久久 | 欧洲色图亚洲色图 | 亚洲精品二区 | 免费在线观看日韩 | 国产香蕉在线视频 | 国产成人精品综合在线观看 | 欧美日韩永久久一区二区三区 | 国产一级视频播放 | a久久99精品久久久久久不 |