初次體驗MyBatis的注意事項
一、MyBatis的HelloWord
1.根據(jù)xml配置文件(全局配置文件mybatis-config.xml)創(chuàng)建一個SqlSessionFactory對象 有數(shù)據(jù)源一些運行環(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;配置了每一個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:唯一標識 resultType:返回值類型 #{id}:從傳遞過來的參數(shù)中取出id值 public Employee getEmpById(Integer id); 分離實現(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í)行增刪改查,一個sqlSession就是代表和數(shù)據(jù)庫的一次會話,用完關閉
SqlSession openSession = sqlSessionFactory.openSession();
3).使用sql的唯一標志來告訴MyBatis執(zhí)行哪個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(實現(xiàn))
接口式編程的好處在于,能夠?qū)⒐δ芘c實現(xiàn)相分離
1、SqlSession代表和數(shù)據(jù)庫的一次會話;用完必須關閉;
2、SqlSession和connection一樣它都是非線程安全。每次使用都應該去獲取新的對象。
3、mapper.java接口沒有實現(xiàn)類,但是mybatis會為這個接口生成一個代理對象。(將接口和xml進行綁定)
EmployeeMapper empMapper = sqlSession.getMapper(EmployeeMapper.class);
4、兩個重要的配置文件:
- mybatis的全局配置文件:包含數(shù)據(jù)庫連接池信息,事務管理器信息等…系統(tǒng)運行環(huán)境信息
- sql映射文件:保存了每一個sql語句的映射信息:將sql抽取出來。
到此這篇關于初次體驗MyBatis的注意事項的文章就介紹到這了,更多相關MyBatis的用法內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
Java8 Supplier接口和Consumer接口原理解析
這篇文章主要介紹了Java8 Supplier接口和Consumer接口原理解析,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2020-04-04springboot使用Logback把日志輸出到控制臺或輸出到文件
這篇文章給大家介紹springboot項目使用日志工具Logback把日志不僅輸出到控制臺,也可以輸出到文件的操作方法,本文通過實例圖文相結(jié)合給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友參考下吧2020-10-10SpringBoot2.0集成WebSocket實現(xiàn)后臺向前端推送信息
這篇文章主要介紹了SpringBoot2.0集成WebSocket實現(xiàn)后臺向前端推送信息,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-01-01Java中的FutureTask實現(xiàn)異步任務代碼實例
這篇文章主要介紹了Java中的FutureTask實現(xiàn)異步任務代碼實例,普通的線程執(zhí)行是無法獲取到執(zhí)行結(jié)果的,FutureTask?間接實現(xiàn)了?Runnable?和?Future?接口,可以得到子線程耗時操作的執(zhí)行結(jié)果,AsyncTask?異步任務就是使用了該機制,需要的朋友可以參考下2024-01-01Java配置JDK開發(fā)環(huán)境及環(huán)境變量
這篇文章主要為大家詳細介紹了Java配置JDK開發(fā)環(huán)境及環(huán)境變量,文中安裝步驟介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-09-09