Talk is cheap, show me the code! 以上這段mybatis的入門案例代碼,相信每一個瞭解mybatis的朋友都能看得懂,知碼醬同學今天也細細品了品! 1. 項目的路徑問題 : 在實際的項目中,並不推薦眾所周知的相對路徑和絕對路徑。 相對路徑: web應用是需要部署到服務 ...
Talk is cheap, show me the code!
public class TestMybatis {
public static void main(String[] args) throws IOException {
//1. 讀取配置文件
InputStream resource = Resources.getResourceAsStream("mybatis.xml");
//2. 創建sqlSessionFactory工廠
SqlSessionFactoryBuilder Builder = new SqlSessionFactoryBuilder();
SqlSessionFactory factory = Builder.build(resource);
//3. 使用工廠模式創建sqlSession對象
SqlSession sqlSession = factory.openSession();
//4. 使用sqlSession對象創建mapper(Dao介面)的代理對象
ItemsMapper mapper = sqlSession.getMapper(ItemsMapper.class);
//5. 使用代理對象執行方法
List<Items> items = mapper.selectAll();
for (Items item : items) {
System.out.println(item);
}
//6. 釋放資源
sqlSession.close();
resource.close();
}
}
以上這段mybatis的入門案例代碼,相信每一個瞭解mybatis的朋友都能看得懂,知碼醬同學今天也細細品了品!
項目的路徑問題 :
Resources.getResourceAsStream("mybatis.xml");
在實際的項目中,並不推薦眾所周知的相對路徑和絕對路徑。- 相對路徑:
src/main/java/xxx.xml
web應用是需要部署到伺服器上的,一旦部署,項目的路徑就會發生改變,然後。。。。一堆404; - 絕對路徑:
F:/project/xxx/xxx.xml
要知道,伺服器可不一定有我們的F盤,況且推薦使用linux系統的伺服器;- 推薦使用
- 使用類載入器,但是它只能載入類路徑的配置文件;
- 使用項目路徑(根路徑)。
- 貼個地址,方便查看 https://blog.csdn.net/chenmh12/article/details/90515148
- 推薦使用
- 相對路徑:
使用構建者模式創建SqlSessionFactory對象
SqlSessionFactoryBuilder Builder = new SqlSessionFactoryBuilder(); SqlSessionFactory factory = Builder.build(resource);
- 什麼是構建者模式呢? 源碼暫且不做探究,我的理解就是點石成金的工程隊,想要黃金(factory),你得提供原材料(resource)吧,道理就這麼簡單!
- ==優點==:隱藏了創建對象的細節,只需調用相應方法就能得到對象!
使用==工廠模式==創建SqlSession對象
SqlSession sqlSession = factory.openSession();
- 工廠模式的使用,使得我們無需手動new一個對象,因為這樣不利於維護(一旦改變需求就要改源代碼,又得重新編譯部署!)
- ==優點==:解耦(降低了類和類之間的依賴關係)
使用==代理模式==創建了mapper(Dao)介面的實現類
java ItemsMapper mapper = sqlSession.getMapper(ItemsMapper.class);
- 代理模式就好比租房的中介,房東只需提供房源,關於租房的事情交給中介(代理),其他什麼都不用管,做自己的事情就行。也就是說使用代理模式,之前的代碼完全不需要改變,也不需要我們創建實現類,代理會幫我們完成這件事情!
- ==優點==:不修改源碼的基礎上對已有方法增強!
總結:這篇文章的出發點是淺顯易懂的理解mybatis入門案例中的設計模式和使用路徑時應該註意的問題,雖然後續學習spring的時候,這些內容也會被隱藏,但目的是為了理解mybatis設計的獨具匠心,關於設計模式的深層次理解,還需要我們多讀一寫其他的相關文章,多推敲設計模式的代碼!