摘要:入門介紹簡介是支持普通查詢存儲過程和高級映射的持久層框架。獨立使用步驟建立類。配置文件主要用于配置程序中可變性高的設置,中的配置文件主要封裝在中。對應于全局配置中的的配置屬性。進行測試代碼實例建立類。針對,注冊類型的,以及用于映射接口的。
MyBatis入門介紹
MyBatis簡介MyBatis是支持普通SQL查詢、存儲過程和高級映射的持久層框架。MyBatis消除了幾乎所有的JDBC代碼和參數的手工設置以及結果集的檢索。MyBatis使用簡單的XML或注解用于配置和原始映射,將接口和Java的POJOs映射成數據庫中的記錄。
一般情況下MyBatis是被Spring整合使用的,但是他也可以獨立使用。
獨立使用MyBatis步驟:建立PO類。用于對數據庫中數據的映射,使程序員更關注對Java類的使用而不是數據庫的操作。
建立Mapper。數據庫操作的映射文件,也就是我們常常說的DAO,用于映射數據庫的操作,可以通過配置文件指定方法對應的SQL語句或者直接使用Java提供餓注解方式進行SQL的指定。
建立配置文件。配置文件主要用于配置程序中可變性高的設置,MyhBatis中的配置文件主要封裝在configuration中。
建立映射文件。對應于MyBatis全局配置中的mappers的配置屬性。主要用于建立對應數據庫操作接口的SQL映射。MyBatis會將這里設定的SQL與對應的Java接口相關聯,以保證在MyBatis中調用接口的時候會到數據庫中執行相應的SQL來簡化開發。
建立測試類。進行測試
代碼實例:
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; } //必須要有這個無參構造器,不然根據UserMapper.xml中的配置,在查詢數據庫的時候,將不能呢過反射構造出User實例 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)測試類
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(); } }
運行結果:
name:wangjun|age:25
補充,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配置移動到了Spring的配置文件中。針對MyBstis,注冊org.mybatis.Spring.SqlsessionFactoryBean類型的bean,以及用于映射接口的org.mybatis.Spring.mapper.MapperFactoryBean。
MyBatis的配置文件簡化。
測試
Spring整合MyBatis很簡單,我們可以看到除了MyBaits配置文件的更改并沒有太大變化。其實Spring整合MyBatis的優勢主要在于使用上,我們來看看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); //查詢數據 User user = um.getUser(1); System.out.println(user.getName()); System.out.println(user.getAge()); //插入數據 User addUser = new User("lujiashaoye", 24); um.insertUser(addUser); } }
我們可以看到,在Spring中使用MyBatis非常方便,用戶甚至無法察覺自己正在使用MyBatis,而這一切相對于獨立使用MyBatis時必須要做的冗余操作來說無非是打打簡化了我們的工作量。
《Spring源碼深度解析》筆記
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/71094.html
摘要:前言由于寫的文章已經是有點多了,為了自己和大家的檢索方便,于是我就做了這么一個博客導航。 前言 由于寫的文章已經是有點多了,為了自己和大家的檢索方便,于是我就做了這么一個博客導航。 由于更新比較頻繁,因此隔一段時間才會更新目錄導航哦~想要獲取最新原創的技術文章歡迎關注我的公眾號:Java3y Java3y文章目錄導航 Java基礎 泛型就這么簡單 注解就這么簡單 Druid數據庫連接池...
摘要:從使用到原理學習線程池關于線程池的使用,及原理分析分析角度新穎面向切面編程的基本用法基于注解的實現在軟件開發中,分散于應用中多出的功能被稱為橫切關注點如事務安全緩存等。 Java 程序媛手把手教你設計模式中的撩妹神技 -- 上篇 遇一人白首,擇一城終老,是多么美好的人生境界,她和他歷經風雨慢慢變老,回首走過的點點滴滴,依然清楚的記得當初愛情萌芽的模樣…… Java 進階面試問題列表 -...
摘要:哪吒社區技能樹打卡打卡貼函數式接口簡介領域優質創作者哪吒公眾號作者架構師奮斗者掃描主頁左側二維碼,加入群聊,一起學習一起進步歡迎點贊收藏留言前情提要無意間聽到領導們的談話,現在公司的現狀是碼農太多,但能獨立帶隊的人太少,簡而言之,不缺干 ? 哪吒社區Java技能樹打卡?【打卡貼 day2...
摘要:簡介我從七月份開始閱讀源碼,并在隨后的天內陸續更新了篇文章。考慮到超長文章對讀者不太友好,以及拆分文章工作量也不小等問題。經過兩周緊張的排版,一本小小的源碼分析書誕生了。我在寫系列文章中,買了一本書作為參考,這本書是技術內幕。 1.簡介 我從七月份開始閱讀MyBatis源碼,并在隨后的40天內陸續更新了7篇文章。起初,我只是打算通過博客的形式進行分享。但在寫作的過程中,發現要分析的代碼...
閱讀 3222·2021-11-23 09:51
閱讀 3566·2021-11-09 09:46
閱讀 3673·2021-11-09 09:45
閱讀 2949·2019-08-29 17:31
閱讀 1867·2019-08-26 13:39
閱讀 2726·2019-08-26 12:12
閱讀 3624·2019-08-26 12:08
閱讀 2243·2019-08-26 11:31