MyBatis和MyBatis-plus教程
MyBatis詳解
Mybatis框架入門教程
MyBatisPlus筆記
狂神說MyBatis01:第一個程序
mybatis看這一篇就夠了,簡單全面一發入魂
三天擼完了MyBatis,各位隨便問!!(冰河吐血整理,建議收藏)
SpringBoot整合Mybatis通用Mapper
Hibernate與MyBatis的區別
Mybatis Select…for update用法
Mybatis中Mapper映射文件詳解
mybatis 根據多個id查詢數據 foreach標簽
MyBatis-Plus,為簡化開發而生,基于3.0.5版本
Mybatis整合spring詳細教程(帶思路)
第04篇:Mybatis代理對象生成
第01篇:Mybatis學習之環境搭建
Mybatis-Plus的介紹和使用
MyBatis是什么?使用它作為持久層框架有什么優點?
學習記錄十一
學習記錄十二
學習記錄十三
mybatis是否已經過時了?
基于 SpringBoot + MyBatis 的在線五子棋對戰
超簡單,Spring boot 配置mybatis
SpringBoot配置Mybatis的三種方式
springboot整合mybatis配置
springBoot整合mybatis
【SSM框架】MyBatis核心配置文件詳解
MyBatis系列學習匯總
MyBatis詳細介紹
MyBatis使用步驟總結
Mybatis的功能相對而言還是比較弱的,缺少了好多必要的輔助庫,字符串處理等等,擴展也比較困難,一般也就可能對返回值進行一些處理。因此最好僅僅把它作為單純的SQL配置文件,以及簡單的ORM框架。不要嘗試在Mybatis中做過多的動態SQL,否則會導致后續的維護非常惡心。到這就要知道一下,Mybatis plus 不香嗎它是在 MyBatis 的基礎上只做增強不做改變,為簡化開發、提高效率而生。
1.特性
無侵入:只做增強不做改變,引入它不會對現有工程產生影響,如絲般順滑
損耗小:啟動即會自動注入基本 CURD,性能基本無損耗,直接面向對象操作
強大的 CRUD 操作:內置通用 Mapper、通用 Service,僅僅通過少量配置即可實現單表大部分 CRUD 操作,更有強大的條件構造器,滿足各類使用需求
支持 Lambda 形式調用:通過 Lambda 表達式,方便的編寫各類查詢條件,無需再擔心字段寫錯
支持主鍵自動生成:支持多達 4 種主鍵策略(內含分布式唯一 ID 生成器 - Sequence),可自由配置,完美解決主鍵問題
支持 ActiveRecord 模式:支持 ActiveRecord 形式調用,實體類只需繼承 Model 類即可進行強大的 CRUD 操作
支持自定義全局通用操作:支持全局通用方法注入( Write once, use anywhere )
內置代碼生成器:采用代碼或者 Maven 插件可快速生成 Mapper 、 Model 、 Service 、 Controller 層代碼,支持模板引擎,更有超多自定義配置等您來使用
內置分頁插件:基于 MyBatis 物理分頁,開發者無需關心具體操作,配置好插件之后,寫分頁等同于普通 List 查詢
分頁插件支持多種數據庫:支持 MySQL、MariaDB、Oracle、DB2、H2、HSQL、SQLite、Postgre、SQLServer 等多種數據庫
內置性能分析插件:可輸出 SQL 語句以及其執行時間,建議開發測試時啟用該功能,能快速揪出慢查詢
內置全局攔截插件:提供全表 delete 、 update 操作智能分析阻斷,也可自定義攔截規則,預防誤操作
總結三大突出特性
1)潤物無聲
只做增強不做改變,引入它不會對現有工程產生影響,如絲般順滑。
2)效率至上
只需簡單配置,即可快速進行單表 CRUD 操作,從而節省大量時間。
3)豐富功能
代碼生成、物理分頁、性能分析等功能一應俱全。
2. 支持數據庫
mysql 、mariadb 、oracle 、db2 、h2 、hsql 、sqlite 、postgresql 、sqlserver 、presto 、Gauss 、Firebird
Phoenix 、clickhouse 、Sybase ASE 、 OceanBase 、達夢數據庫 、虛谷數據庫 、人大金倉數據庫 、南大通用數據庫
3. 框架結構
10. 動態sql
UserMapper
<?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE mapperPUBLIC "-//mybatis.org//DTD Mapper 3.0//EN""http://mybatis.org/dtd/mybatis-3-mapper.dtd"> <mapper namespace="cn.itcast.mybatis.mapper.UserMapper"><!-- <sql id="commonSql">id,user_name,password,name,age,sex,birthday,created,updated</sql> --><select id="loginByMap" resultType="User">select * from tb_user where user_name=#{userName} and password=#{password}</select><select id="login" resultType="User">select * from tb_user where user_name=#{userName} and password=#{password}</select><select id="queryUsersByTableName" resultType="User">select * from ${tableName}</select><select id="queryUserById" resultType="User" parameterType="long">select * from tb_user where id = #{id}</select><resultMap id="userMap" type="User" autoMapping="true"><id column="id" property="id"/></resultMap><select id="queryUserById1" resultMap="userMap">select * from tb_user where id = #{id}</select><select id="queryUserAll" resultType="User" >select * from tb_user</select><insert id="insertUser" parameterType="User">INSERT INTO tb_user (user_name,password,name,age,sex,birthday,created,updated)VALUES(#{userName},#{password},#{name},#{age},#{sex},#{birthday},NOW(),NOW());</insert><update id="updateUser" parameterType="User">UPDATE tb_userSETuser_name = #{userName},password = #{password},name = #{name},age = #{age},sex = #{sex},birthday = #{birthday},updated = NOW()WHERE(id = #{id});</update><delete id="deleteUserById" parameterType="java.lang.Long">delete from tb_user where id=#{id}</delete><select id="queryUsersLikeUserName" resultType="User"><!-- select <include refid="CommonSQL.commonSql"></include> from tb_user where user_name like '%' #{userName} '%'--><!-- if:判斷 test:OGNL表達式-->select * from tb_user where sex=3<if test="userName!=null and userName.trim()!=''">and user_name like '%' #{userName} '%'</if></select><select id="queryUserListLikeUserNameOrAge" resultType="User">select * from tb_user where sex=3<!-- choose:條件選擇when:test-判斷條件,一旦有一個when成立,后續的when都不再執行otherwise:所有的when都不成立時,才會執行--><choose><when test="userName!=null and userName.trim()!=''">and user_name like '%' #{userName} '%'</when><when test="age != null">and age = #{age}</when><otherwise>and user_name = 'zhangsan' </otherwise></choose></select><select id="queryUserListLikeUserNameAndAge" resultType="User">select * from tb_user<!--自動添加where關鍵字有一定的糾錯功能:去掉sql語句塊之前多余的一個and|or通常結合if或者choose使用--><where><if test="userName!=null and userName.trim()!=''">user_name like '%' #{userName} '%'</if><if test="age!=null">and age = #{age}</if></where></select><select id="queryUserListByIds" resultType="User">select * from tb_user where id in<!--foreach:遍歷集合collection:接收的集合參數item:遍歷的集合中的一個元素separator:分隔符open:以什么開始close:以什么結束--><foreach collection="ids" item="id" separator="," open="(" close=")">#{id}</foreach></select><update id="updateUserSelective">UPDATE tb_user<!--set自動添加set關鍵字也有一定的糾錯功能:自動去掉sql語句塊之后多余的一個逗號--><set><if test="userName!=null and userName.trim()!=''">user_name = #{userName},</if><if test="password!=null and password.trim()!=''">password = #{password},</if><if test="name!=null and name.trim()!=''">name = #{name},</if><if test="age!=null">age = #{age},</if><if test="sex!=null">sex = #{sex},</if>updated = now(),</set>WHERE(id = #{id});</update></mapper>UserMapper.xml
<?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE mapperPUBLIC "-//mybatis.org//DTD Mapper 3.0//EN""http://mybatis.org/dtd/mybatis-3-mapper.dtd"> <mapper namespace="cn.itcast.mybatis.mapper.UserMapper"><!-- <sql id="commonSql">id,user_name,password,name,age,sex,birthday,created,updated</sql> --><select id="loginByMap" resultType="User">select * from tb_user where user_name=#{userName} and password=#{password}</select><select id="login" resultType="User">select * from tb_user where user_name=#{userName} and password=#{password}</select><select id="queryUsersByTableName" resultType="User">select * from ${tableName}</select><select id="queryUserById" resultType="User" parameterType="long">select * from tb_user where id = #{id}</select><resultMap id="userMap" type="User" autoMapping="true"><id column="id" property="id"/></resultMap><select id="queryUserById1" resultMap="userMap">select * from tb_user where id = #{id}</select><select id="queryUserAll" resultType="User" >select * from tb_user</select><insert id="insertUser" parameterType="User">INSERT INTO tb_user (user_name,password,name,age,sex,birthday,created,updated)VALUES(#{userName},#{password},#{name},#{age},#{sex},#{birthday},NOW(),NOW());</insert><update id="updateUser" parameterType="User">UPDATE tb_userSETuser_name = #{userName},password = #{password},name = #{name},age = #{age},sex = #{sex},birthday = #{birthday},updated = NOW()WHERE(id = #{id});</update><delete id="deleteUserById" parameterType="java.lang.Long">delete from tb_user where id=#{id}</delete><select id="queryUsersLikeUserName" resultType="User"><!-- select <include refid="CommonSQL.commonSql"></include> from tb_user where user_name like '%' #{userName} '%'--><!-- if:判斷 test:OGNL表達式-->select * from tb_user where sex=3<if test="userName!=null and userName.trim()!=''">and user_name like '%' #{userName} '%'</if></select><select id="queryUserListLikeUserNameOrAge" resultType="User">select * from tb_user where sex=3<!-- choose:條件選擇when:test-判斷條件,一旦有一個when成立,后續的when都不再執行otherwise:所有的when都不成立時,才會執行--><choose><when test="userName!=null and userName.trim()!=''">and user_name like '%' #{userName} '%'</when><when test="age != null">and age = #{age}</when><otherwise>and user_name = 'zhangsan' </otherwise></choose></select><select id="queryUserListLikeUserNameAndAge" resultType="User">select * from tb_user<!--自動添加where關鍵字有一定的糾錯功能:去掉sql語句塊之前多余的一個and|or通常結合if或者choose使用--><where><if test="userName!=null and userName.trim()!=''">user_name like '%' #{userName} '%'</if><if test="age!=null">and age = #{age}</if></where></select><select id="queryUserListByIds" resultType="User">select * from tb_user where id in<!--foreach:遍歷集合collection:接收的集合參數item:遍歷的集合中的一個元素separator:分隔符open:以什么開始close:以什么結束--><foreach collection="ids" item="id" separator="," open="(" close=")">#{id}</foreach></select><update id="updateUserSelective">UPDATE tb_user<!--set自動添加set關鍵字也有一定的糾錯功能:自動去掉sql語句塊之后多余的一個逗號--><set><if test="userName!=null and userName.trim()!=''">user_name = #{userName},</if><if test="password!=null and password.trim()!=''">password = #{password},</if><if test="name!=null and name.trim()!=''">name = #{name},</if><if test="age!=null">age = #{age},</if><if test="sex!=null">sex = #{sex},</if>updated = now(),</set>WHERE(id = #{id});</update></mapper>User
package cn.itcast.mybatis.pojo;import java.util.Date;public class User {private Long id;// 用戶名private String userName;// 密碼private String password;// 姓名private String name;// 年齡private Integer age;// 性別,1男性,2女性private Integer sex;// 出生日期private Date birthday;// 創建時間private Date created;// 更新時間private Date updated;public Long getId() {return id;}public void setId(Long id) {this.id = id;}public String getUserName() {return userName;}public void setUserName(String userName) {this.userName = userName;}public String getPassword() {return password;}public void setPassword(String password) {this.password = password;}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;}public Integer getSex() {return sex;}public void setSex(Integer sex) {this.sex = sex;}public Date getBirthday() {return birthday;}public void setBirthday(Date birthday) {this.birthday = birthday;}public Date getCreated() {return created;}public void setCreated(Date created) {this.created = created;}public Date getUpdated() {return updated;}public void setUpdated(Date updated) {this.updated = updated;}@Overridepublic String toString() {return "User [id=" + id + ", userName=" + userName + ", password=" + password + ", name=" + name+ ", age=" + age + ", sex=" + sex + ", birthday=" + birthday + ", created=" + created+ ", updated=" + updated + "]";}}UserMapperTest
package cn.itcast.mybatis.mapper;import cn.itcast.mybatis.pojo.User; import org.apache.ibatis.io.Resources; import org.apache.ibatis.session.SqlSession; import org.apache.ibatis.session.SqlSessionFactory; import org.apache.ibatis.session.SqlSessionFactoryBuilder; import org.junit.Before; import org.junit.Test;import java.io.InputStream; import java.util.Date; import java.util.HashMap; import java.util.List; import java.util.Map;public class UserMapperTest {private UserMapper userMapper;@Beforepublic void setUp() throws Exception { // 讀取mybatis的全局配置文件InputStream inputStream = Resources.getResourceAsStream("mybatis-config.xml");// 構建sqlSessionFactorySqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream,"test");// 獲取sqlSession會話, true 表示自動提交事務SqlSession sqlSession = sqlSessionFactory.openSession(true);// 初始化userDaothis.userMapper = sqlSession.getMapper(UserMapper.class);}@Testpublic void testQueryUsersLikeUserName(){List<User> users = this.userMapper.queryUsersLikeUserName("rick");for (User user : users) {System.out.println(user);}}@Testpublic void testMap(){Map<String,Object> map = new HashMap<>();map.put("userName", "zhangsan");map.put("password", "00000");System.out.println(this.userMapper.loginByMap(map));}@Testpublic void testLogin(){System.out.println(this.userMapper.login("lisi", "456"));}@Testpublic void testQueryUsersByTableName(){List<User> users = this.userMapper.queryUsersByTableName("tb_user");for (User user : users) {System.out.println(user);}}@Testpublic void queryUserById() {User user = this.userMapper.queryUserById1(1L);System.out.println(user);}@Testpublic void testQueryUserAll() {List<User> userList = this.userMapper.queryUserAll();for (User user : userList) {System.out.println(user);}}@Testpublic void testQueryUserListLikeUserNameOrAge(){List<User> users = this.userMapper.queryUserListLikeUserNameOrAge(null, 18);for (User user : users) {System.out.println(user);}}@Testpublic void testQueryUserListLikeUserNameAndAge(){List<User> users = this.userMapper.queryUserListLikeUserNameAndAge("yanyan", 18);for (User user : users) {System.out.println(user);}}@Testpublic void testUpdateUserSelective(){User user = new User();user.setAge(16);user.setName("Lydia");user.setPassword("789");user.setUserName("yanyan2");user.setSex(3);user.setBirthday(new Date());user.setId(11L);this.userMapper.updateUserSelective(user);}@Testpublic void testQueryUserListByIds(){List<User> users = this.userMapper.queryUserListByIds(new Long[]{1L,2L,3L,4L});for (User user : users) {System.out.println(user);}}}mybatis-config.xml
<?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE configurationPUBLIC "-//mybatis.org//DTD Config 3.0//EN""http://mybatis.org/dtd/mybatis-3-config.dtd"> <configuration><!-- 引入外部資源文件,resource:相對路徑,url:絕對路徑 --><properties resource="jdbc.properties"/><settings><setting name="mapUnderscoreToCamelCase" value="true"/></settings><typeAliases><!-- <typeAlias type="cn.itcast.mybatis.pojo.User" alias="user"/> --><package name="cn.itcast.mybatis.pojo"/></typeAliases><environments default="test"><environment id="development"><transactionManager type="JDBC"/><dataSource type="POOLED"><property name="driver" value="${jdbc.driver}"/><property name="url" value="${jdbc.url}"/><property name="username" value="${jdbc.username}"/><property name="password" value="${jdbc.password}"/></dataSource></environment><environment id="test"><transactionManager type="JDBC"/><dataSource type="POOLED"><property name="driver" value="${jdbc.driver}"/><property name="url" value="${jdbc.url}"/><property name="username" value="${jdbc.username}"/><property name="password" value="${jdbc.password}"/></dataSource></environment></environments><mappers><mapper resource="UserMapper.xml"/><mapper resource="UserDaoMapper.xml"/><mapper resource="CommonSQL.xml"/><!-- <mapper class="cn.itcast.mybatis.mapper.UserMapper"/><package name="cn.itcast.mybatis.mapper"/> --></mappers> </configuration>jdbc.properties
jdbc.driver = com.mysql.jdbc.Driver jdbc.url = jdbc:mysql:///user_manager jdbc.username = root jdbc.password = root總結
以上是生活随笔為你收集整理的MyBatis和MyBatis-plus教程的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 临时邮箱如何申请注册,申请临时邮箱后有什
- 下一篇: The SwiftProgramming