您好,登錄后才能下訂單哦!
這篇文章給大家介紹怎么快速配置一個(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&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(); } } }
在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需要的配置就已全部完成。
在 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ò),可以把它分享出去讓更多的人看到。
免責(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)容。