初次體驗(yàn)MyBatis的注意事項(xiàng)
一、MyBatis的HelloWord
1.根據(jù)xml配置文件(全局配置文件mybatis-config.xml)創(chuàng)建一個(gè)SqlSessionFactory對象 有數(shù)據(jù)源一些運(yùn)行環(huán)境信息
<?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">
<configuration>
<environments default="development">
<environment id="development">
<transactionManager type="JDBC" />
<dataSource type="POOLED">
<property name="driver" value="com.mysql.jdbc.Driver" />
<property name="url" value="jdbc:mysql://localhost:3306/mybatis" />
<property name="username" value="root" />
<property name="password" value="123456" />
</dataSource>
</environment>
</environments>
<!-- 將我們寫好的sql映射文件(EmployeeMapper.xml)一定要注冊到全局配置文件(mybatis-config.xml)中 -->
<mappers>
<mapper resource="EmployeeMapper.xml" />
</mappers>
</configuration>
2.sql映射文件EmployeeMapper.xml;配置了每一個(gè)sql,以及sql的封裝規(guī)則等。
<?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">
<mapper namespace="com.atguigu.mybatis.dao.EmployeeMapper">
<!--
namespace:名稱空間;指定為接口的全類名
id:唯一標(biāo)識
resultType:返回值類型
#{id}:從傳遞過來的參數(shù)中取出id值
public Employee getEmpById(Integer id);
分離實(shí)現(xiàn)與接口
-->
<select id="getEmpById" resultType="com.atguigu.mybatis.bean.Employee">
select id,last_name lastName,email,gender from tbl_employee where id = #{id}
</select>
</mapper>
3.將sql映射文件注冊在全局配置文件mybatis-config.xml中
<mappers> <mapper resource="EmployeeMapper.xml" /> </mappers>
4.寫代碼:
1).根據(jù)全局配置文件得到SqlSessionFactory;
String resource = "mybatis-config.xml"; InputStream inputStream = Resources.getResourceAsStream(resource); SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
2).使用sqlSession工廠,獲取到sqlSession對象使用他來執(zhí)行增刪改查,一個(gè)sqlSession就是代表和數(shù)據(jù)庫的一次會(huì)話,用完關(guān)閉
SqlSession openSession = sqlSessionFactory.openSession();
3).使用sql的唯一標(biāo)志來告訴MyBatis執(zhí)行哪個(gè)sql。sql都是保存在sql映射文件中的
try {
Employee employee = openSession.selectOne(
"com.atguigu.mybatis.dao.EmployeeMapper.getEmpById", 1); // spacename + sqlId
System.out.println(employee);
} finally {
openSession.close();
}
二、MyBatis接口式編程
mybatis: Mapper.java(接口) ====> xxMapper.xml(實(shí)現(xiàn))
接口式編程的好處在于,能夠?qū)⒐δ芘c實(shí)現(xiàn)相分離
1、SqlSession代表和數(shù)據(jù)庫的一次會(huì)話;用完必須關(guān)閉;
2、SqlSession和connection一樣它都是非線程安全。每次使用都應(yīng)該去獲取新的對象。
3、mapper.java接口沒有實(shí)現(xiàn)類,但是mybatis會(huì)為這個(gè)接口生成一個(gè)代理對象。(將接口和xml進(jìn)行綁定)
EmployeeMapper empMapper = sqlSession.getMapper(EmployeeMapper.class);
4、兩個(gè)重要的配置文件:
- mybatis的全局配置文件:包含數(shù)據(jù)庫連接池信息,事務(wù)管理器信息等…系統(tǒng)運(yùn)行環(huán)境信息
- sql映射文件:保存了每一個(gè)sql語句的映射信息:將sql抽取出來。
到此這篇關(guān)于初次體驗(yàn)MyBatis的注意事項(xiàng)的文章就介紹到這了,更多相關(guān)MyBatis的用法內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
SpringMVC文件上傳原理及實(shí)現(xiàn)過程解析
這篇文章主要介紹了SpringMVC文件上傳原理及實(shí)現(xiàn)過程解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-07-07
Java中用戶向系統(tǒng)傳遞參數(shù)的三種基本方式實(shí)例分享
這篇文章主要介紹了Java中用戶向系統(tǒng)傳遞參數(shù)的三種基本方式實(shí)例,有需要的朋友可以參考一下2014-01-01
Hibernate validator使用以及自定義校驗(yàn)器注解
這篇文章主要介紹了Hibernate validator使用以及自定義校驗(yàn)器注解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-01-01
Spring中的@ControllerAdvice和@ExceptionHandler注解處理全局異常
這篇文章主要介紹了Spring中的@ControllerAdvice和@ExceptionHandler注解處理全局異常,@ControllerAdvice ,@ControllerAdvice是一個(gè)非常有用的注解,顧名思義,這是一個(gè)增強(qiáng)的 Controller,一般配合@ExceptionHandler使用來處理全局異常,需要的朋友可以參考下2024-01-01
MySQL中關(guān)鍵字UNION和UNION ALL的區(qū)別
本文主要介紹了MySQL中關(guān)鍵字UNION和UNION ALL的區(qū)別,深入探討UNION和UNION ALL的定義、用法、主要區(qū)別,具有一定的參考價(jià)值,感興趣的可以了解一下2024-06-06
關(guān)于SpringCloud中Ribbon的7種負(fù)載均衡策略解析
這篇文章主要介紹了關(guān)于SpringCloud中Ribbon的7種負(fù)載均衡策略解析,服務(wù)端負(fù)載均衡器的問題是,它提供了更強(qiáng)的流量控制權(quán),但無法滿足不同的消費(fèi)者希望使用不同負(fù)載均衡策略的需求,而使用不同負(fù)載均衡策略的場景確實(shí)是存在的,需要的朋友可以參考下2023-07-07

