Mybatis01-建立一個簡單的mybatis專案
1.新建專案
- 新建一個普通的maven專案
- 刪除src目錄(作為父工程)
- 匯入maven依賴
<dependencies> <!--mysql驅動--> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>8.0.27</version> </dependency> <!--mybatis--> <dependency> <groupId>org.mybatis</groupId> <artifactId>mybatis</artifactId> <version>3.5.9</version> </dependency> <!--junit--> <dependency> <groupId>junit</groupId> <artifactId>junit</artifactId> <version>4.13.2</version> </dependency> </dependencies>
2.建立mybatis核心配置檔案
<?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.cj.jdbc.Driver"/><!--環境--> <property name="url" value="jdbc:mysql://localhost:3306/mybatis?useSSL=true&useUnicode=true&characterEncoding=utf-8&serverTimezone=GMT"/> <property name="username" value="root"/> <property name="password" value="6113081"/> </dataSource> </environment> </environments> <!--對映mapper介面--> <mappers> <mapper resource="com/zhang/mapper/UserMapper.xml"></mapper> </mappers> </configuration>
3.編寫一個mybatis工具類(類似於jducUtil工具類)
public class MybatisUtils { private static SqlSessionFactory sqlSessionFactory; /** * 每個基於 MyBatis 的應用都是以一個 SqlSessionFactory 的例項為核心的。 * SqlSessionFactory 的例項可以通過 SqlSessionFactoryBuilder 獲得。 * 而 SqlSessionFactoryBuilder 則可以從 XML 配置檔案或一個預先配置的 Configuration 例項來構建出 SqlSessionFactory 例項。 */ static { String resource = "mybatis-config.xml"; try { InputStream inputStream = Resources.getResourceAsStream(resource); sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream); } catch (IOException e) { e.printStackTrace(); } } /** * SqlSession 完全包含了面向資料庫執行sql命令所需的所有方法 * @return */ public static SqlSession getSqlSession() { return sqlSessionFactory.openSession(); } }
4.編寫mapper介面(原Dao層介面,提供方法)
public interface UserMapper {
List<User> getUserList();
}
5.建立包含mapper介面對映關係的xml配置檔案(原先編寫介面方法實現類)
<?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">
<!--namespace綁定了一個對應的Dao/mapper介面-->
<!--此處的mapper配置相當於轉換了原先Dao中的介面實現類,相當於此xml檔案實現了Mapper介面中的方法-->
<mapper namespace="com.zhang.dao.UserDao">
<!--select查詢方法,id表示為mapper介面的實現方法,resultType表示該方法返回型別-->
<select id="getUserList" resultType="com.zhang.pojo.User"><!--返回結果集型別,可以單寫返回型別但不推薦-->
select * from user ;
</select>
</mapper>
6.對應的實體類建立(略)
7.編寫測試方法
public class UserDaoTest {
@Test
public void test(){
//1.獲取sqlsession物件
SqlSession sqlSession01 = MybatisUtils.getSqlSession();
//2.方式一:getMapper(執行sql)
UserDao mapper = sqlSession01.getMapper(UserDao.class);
List<User> userList = mapper.getUserList();
for (User user : userList) {
System.out.println(user.toString());
}
sqlSession01.close();
//3.方式二:(不推薦)
SqlSession sqlSession02 = MybatisUtils.getSqlSession();
List<User> users= sqlSession02.selectList("com.zhang.dao.UserDao.getUserList");
for (User user : users) {
System.out.println(user.toString());
}
sqlSession02.close();
}
}
8.結果
User{id=1, name='zhangsan', pwd='123456'}
User{id=2, name='lisi', pwd='123456'}
User{id=3, name='wangwu', pwd='123456'}
User{id=1, name='zhangsan', pwd='123456'}
User{id=2, name='lisi', pwd='123456'}
User{id=3, name='wangwu', pwd='123456'}
9.總結
核心要素4點
-
1.SqlSessionFactoryBuilder
這個類可以被例項化、使用和丟棄,一旦建立了 SqlSessionFactory,就不再需要它了。 因此 SqlSessionFactoryBuilder 例項的最佳作用域是方法作用域(也就是區域性方法變數)。 你可以重用 SqlSessionFactoryBuilder 來建立多個 SqlSessionFactory 例項,但最好還是不要一直保留著它,以保證所有的 XML 解析資源可以被釋放給更重要的事情。 -
2.SqlSessionFactory
SqlSessionFactory 一旦被建立就應該在應用的執行期間一直存在,沒有任何理由丟棄它或重新建立另一個例項。 使用 SqlSessionFactory 的最佳實踐是在應用執行期間不要重複建立多次,多次重建 SqlSessionFactory 被視為一種程式碼“壞習慣”。因此 SqlSessionFactory 的最佳作用域是應用作用域。 有很多方法可以做到,最簡單的就是使用單例模式或者靜態單例模式。 -
3.SqlSession
每個執行緒都應該有它自己的 SqlSession 例項。SqlSession 的例項不是執行緒安全的,因此是不能被共享的,所以它的最佳的作用域是請求或方法作用域。 絕對不能將 SqlSession 例項的引用放在一個類的靜態域,甚至一個類的例項變數也不行。 也絕不能將 SqlSession 例項的引用放在任何型別的託管作用域中,比如 Servlet 框架中的 HttpSession。 如果你現在正在使用一種 Web 框架,考慮將 SqlSession 放在一個和 HTTP 請求相似的作用域中。 換句話說,每次收到 HTTP 請求,就可以開啟一個 SqlSession,返回一個響應後,就關閉它。 這個關閉操作很重要,為了確保每次都能執行關閉操作,你應該把這個關閉操作放到 finally 塊中。 -
4.對映器例項
對映器是一些繫結對映語句的介面。對映器介面的例項是從 SqlSession 中獲得的。雖然從技術層面上來講,任何對映器例項的最大作用域與請求它們的 SqlSession 相同。但方法作用域才是對映器例項的最合適的作用域。 也就是說,對映器例項應該在呼叫它們的方法中被獲取,使用完畢之後即可丟棄。 對映器例項並不需要被顯式地關閉。儘管在整個請求作用域保留對映器例項不會有什麼問題,但是你很快會發現,在這個作用域上管理太多像 SqlSession 的資源會讓你忙不過來。 因此,最好將對映器放在方法作用域內。