摘要:入門(mén)使用簡(jiǎn)介是支持普通查詢存儲(chǔ)過(guò)程和高級(jí)映射的持久層框架。一般情況下是被整合使用的,但是他也可以獨(dú)立使用。獨(dú)立使用步驟建立類。配置文件主要用于配置程序中可變性高的設(shè)置,中的配置文件主要封裝在中。針對(duì),注冊(cè)類型的,以及用于映射接口的。
MyBatis入門(mén)使用 MyBatis簡(jiǎn)介
MyBatis是支持普通SQL查詢、存儲(chǔ)過(guò)程和高級(jí)映射的持久層框架。MyBatis消除了幾乎所有的JDBC代碼和參數(shù)的手工設(shè)置以及結(jié)果集的檢索。MyBatis使用簡(jiǎn)單的XML或注解用于配置和原始映射,將接口和Java的POJOs映射成數(shù)據(jù)庫(kù)中的記錄。
一般情況下MyBatis是被Spring整合使用的,但是他也可以獨(dú)立使用。
獨(dú)立使用MyBatis步驟:建立PO類。用于對(duì)數(shù)據(jù)庫(kù)中數(shù)據(jù)的映射,使程序員更關(guān)注對(duì)Java類的使用而不是數(shù)據(jù)庫(kù)的操作。
建立Mapper。數(shù)據(jù)庫(kù)操作的映射文件,也就是我們常常說(shuō)的DAO,用于映射數(shù)據(jù)庫(kù)的操作,可以通過(guò)配置文件指定方法對(duì)應(yīng)的SQL語(yǔ)句或者直接使用Java提供餓注解方式進(jìn)行SQL的指定。
建立配置文件。配置文件主要用于配置程序中可變性高的設(shè)置,MyhBatis中的配置文件主要封裝在configuration中。
建立映射文件。對(duì)應(yīng)于MyBatis全局配置中的mappers的配置屬性。主要用于建立對(duì)應(yīng)數(shù)據(jù)庫(kù)操作接口的SQL映射。MyBatis會(huì)將這里設(shè)定的SQL與對(duì)應(yīng)的Java接口相關(guān)聯(lián),以保證在MyBatis中調(diào)用接口的時(shí)候會(huì)到數(shù)據(jù)庫(kù)中執(zhí)行相應(yīng)的SQL來(lái)簡(jiǎn)化開(kāi)發(fā)。
建立測(cè)試類。進(jìn)行測(cè)試
代碼實(shí)例:
1)建立PO類。
package com.wangjun.mybatis.test.mybatis; public class User { private Integer id; private String name; private Integer age; public User(String name, Integer age) { super(); this.name = name; this.age = age; } //必須要有這個(gè)無(wú)參構(gòu)造器,不然根據(jù)UserMapper.xml中的配置,在查詢數(shù)據(jù)庫(kù)的時(shí)候,將不能呢過(guò)反射構(gòu)造出User實(shí)例 public User() { } public Integer getId() { return id; } public void setId(Integer id) { this.id = id; } public String getName() { return name; } public void setName(String name) { this.name = name; } public Integer getAge() { return age; } public void setAge(Integer age) { this.age = age; } }
2)建立Mapper。
package com.wangjun.mybatis.test.mybatis; public interface UserMapper { public void insertUser(User user); public User getUser(Integer id); }
3)建立配置文件。
4)建立映射文件。
insert into user(name,age) values(#{name},#{age})
5)測(cè)試類
package com.wangjun.mybatis.test.mybatis; import java.io.IOException; import java.io.Reader; import org.apache.ibatis.io.Resources; import org.apache.ibatis.session.SqlSessionFactory; import org.apache.ibatis.session.SqlSessionFactoryBuilder; public class MyBatisUtil { private final static SqlSessionFactory sqlSessionFactory; static { String resource = "configuration.xml"; Reader reader = null; try { reader = Resources.getResourceAsReader(resource); } catch (IOException e) { e.printStackTrace(); } sqlSessionFactory = new SqlSessionFactoryBuilder().build(reader); } public static SqlSessionFactory getSqlSessionFactory() { return sqlSessionFactory; } }
package com.wangjun.mybatis.test.mybatis; import org.apache.ibatis.session.SqlSession; import org.apache.ibatis.session.SqlSessionFactory; public class TestMapper { static SqlSessionFactory sqlSessionFactory = null; static { System.out.println(111); sqlSessionFactory = MyBatisUtil.getSqlSessionFactory(); } public void testAdd() { SqlSession sqlSession = sqlSessionFactory.openSession(); try { UserMapper userMapper = sqlSession.getMapper(UserMapper.class); User user = new User("wangjun", new Integer(25)); userMapper.insertUser(user); sqlSession.commit(); }finally { sqlSession.close(); } } public void getUser() { SqlSession sqlSession = sqlSessionFactory.openSession(); try { UserMapper userMapper = sqlSession.getMapper(UserMapper.class); User user = userMapper.getUser(1); System.out.println("name:" + user.getName() + "|age:" + user.getAge()); }finally { sqlSession.close(); } } public static void main(String[] args) { TestMapper tm = new TestMapper(); tm.testAdd(); tm.getUser(); } }
運(yùn)行結(jié)果:
name:wangjun|age:25
補(bǔ)充,POM文件配置:需要依賴jdbc和myBaits
Spring整合MyBatis步驟:4.0.0 com.wangjun.mybatis test.mybatis 0.0.1-SNAPSHOT jar test.mybatis http://maven.apache.org UTF-8 junit junit 3.8.1 test mysql mysql-connector-java 6.0.6 org.mybatis mybatis 3.4.5
上述步驟的1,2,3步不變。只需要配置Spring文件:
將MyBatis配置文件的environments配置移動(dòng)到了Spring的配置文件中。針對(duì)MyBstis,注冊(cè)org.mybatis.Spring.SqlsessionFactoryBean類型的bean,以及用于映射接口的org.mybatis.Spring.mapper.MapperFactoryBean。
?
MyBatis的配置文件簡(jiǎn)化。
?
測(cè)試
Spring整合MyBatis很簡(jiǎn)單,我們可以看到除了MyBaits配置文件的更改并沒(méi)有太大變化。其實(shí)Spring整合MyBatis的優(yōu)勢(shì)主要在于使用上,我們來(lái)看看Spring中使用MyBatis的用法:
package com.wangjun.mybatis.test.mybatis; import org.springframework.context.ApplicationContext; import org.springframework.context.support.ClassPathXmlApplicationContext; public class SpringMyBatisTest { public static void main(String[] args) { ApplicationContext context = new ClassPathXmlApplicationContext("mybatis/springMyBatis.xml"); UserMapper um = context.getBean("userMapper", UserMapper.class); //查詢數(shù)據(jù) User user = um.getUser(1); System.out.println(user.getName()); System.out.println(user.getAge()); //插入數(shù)據(jù) User addUser = new User("lujiashaoye", 24); um.insertUser(addUser); } }
我們可以看到,在Spring中使用MyBatis非常方便,用戶甚至無(wú)法察覺(jué)自己正在使用MyBatis,而這一切相對(duì)于獨(dú)立使用MyBatis時(shí)必須要做的冗余操作來(lái)說(shuō)無(wú)非是打打簡(jiǎn)化了我們的工作量。
《Spring源碼深度解析》筆記
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://m.hztianpu.com/yun/69280.html
摘要:入門(mén)介紹簡(jiǎn)介是支持普通查詢存儲(chǔ)過(guò)程和高級(jí)映射的持久層框架。獨(dú)立使用步驟建立類。配置文件主要用于配置程序中可變性高的設(shè)置,中的配置文件主要封裝在中。對(duì)應(yīng)于全局配置中的的配置屬性。進(jìn)行測(cè)試代碼實(shí)例建立類。針對(duì),注冊(cè)類型的,以及用于映射接口的。 MyBatis入門(mén)介紹 MyBatis簡(jiǎn)介 MyBatis是支持普通SQL查詢、存儲(chǔ)過(guò)程和高級(jí)映射的持久層框架。MyBatis消除了幾乎所有的JDB...
摘要:的實(shí)例不是線程安全的,因此是不能被共享的,所以它的最佳的作用域是請(qǐng)求或方法作用域。下面的示例就是一個(gè)確保關(guān)閉的標(biāo)準(zhǔn)模式依賴注入框架可以創(chuàng)建線程安全的基于事務(wù)的和映射器并將它們直接注入到你的中,因此可以直接忽略它們的生命周期。 MyBatis理解與掌握(入門(mén)例子) @(MyBatis)[Java, 框架, MyBatis] 配置文件 mybatis-config.xml ...
摘要:哪吒社區(qū)技能樹(shù)打卡打卡貼函數(shù)式接口簡(jiǎn)介領(lǐng)域優(yōu)質(zhì)創(chuàng)作者哪吒公眾號(hào)作者架構(gòu)師奮斗者掃描主頁(yè)左側(cè)二維碼,加入群聊,一起學(xué)習(xí)一起進(jìn)步歡迎點(diǎn)贊收藏留言前情提要無(wú)意間聽(tīng)到領(lǐng)導(dǎo)們的談話,現(xiàn)在公司的現(xiàn)狀是碼農(nóng)太多,但能獨(dú)立帶隊(duì)的人太少,簡(jiǎn)而言之,不缺干 ? 哪吒社區(qū)Java技能樹(shù)打卡?【打卡貼 day2...
摘要:一使用快速創(chuàng)建項(xiàng)目關(guān)于如何快速創(chuàng)建項(xiàng)目,這個(gè)可以參考下面這篇文章項(xiàng)目管理工具基礎(chǔ)入門(mén)系列一二快速配置依賴包打開(kāi)文件,快速配置包,配置代碼如下依賴包數(shù)據(jù)庫(kù)驅(qū)動(dòng)依賴包測(cè)試依賴包三快速創(chuàng)建實(shí)體類創(chuàng)建類,代碼如下四 一、使用 IDEA 快速創(chuàng)建 Maven 項(xiàng)目 關(guān)于如何快速創(chuàng)建 Maven 項(xiàng)目,這個(gè)可以參考下面這篇文章: Maven 項(xiàng)目管理工具基礎(chǔ)入門(mén)系列(一) 二、快速配置 MyBat...
摘要:歷史文章如何在安裝最新版安裝安裝最新版教程內(nèi)容備注本系列開(kāi)發(fā)工具均為構(gòu)建項(xiàng)目,選擇四個(gè)基本的依賴。層與其實(shí)現(xiàn),這個(gè)比較簡(jiǎn)單,一般做過(guò)項(xiàng)目的都了解層,我這邊構(gòu)建了一個(gè)方法,通過(guò)獲取信息。 本博客 貓叔的博客,轉(zhuǎn)載請(qǐng)申明出處本系列教程為HMStrange項(xiàng)目附帶。 歷史文章 如何在VMware12安裝Centos7.6最新版 Centos7.6安裝Java8 Centos7.6安裝My...
閱讀 3218·2023-04-25 18:22
閱讀 2508·2021-11-17 09:33
閱讀 3618·2021-10-11 10:59
閱讀 3304·2021-09-22 15:50
閱讀 2938·2021-09-10 10:50
閱讀 921·2019-08-30 15:53
閱讀 508·2019-08-29 11:21
閱讀 3042·2019-08-26 13:58