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-config.xml 全局的配置文件 (1、数据源,2、外部的mapper)
- 创建XxxMapper.xml 映射文件(写sql语句)
- 创建SqlSessionFactory
- 通过SqlSessionFactory创建SqlSession对象
- 通过SqlSession操作数据库 CRUD
- 调用session.commit()提交事务
- 调用session.close()关闭会话
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教程相关推荐
- Spring+SpringMVC+Mybatis框架集成搭建教程
一.背景 最近有很多同学由于没有过SSM(Spring+SpringMvc+Mybatis , 以下简称SSM)框架的搭建的经历,所以在自己搭建SSM框架集成的时候,出现了这样或者那样的问题,很是苦恼 ...
- Spring+SpringMVC+MyBatis框架搭建-----详细教程
1.基本概念 1.1Spring Spring是一个开源框架,Spring是于2003 年兴起的一个轻量级的Java 开发框架,由Rod Johnson 在其著作Expert One-On-One J ...
- Eclipse中实现SpringBoot与Mybatis整合(图文教程带源码)
场景 数据库中数据 实现效果 项目结构 前面参照 Eclipse中新建SpringBoot项目并输出HelloWorld https://blog.csdn.net/BADAO_LIUMANG_QIZ ...
- MyBatis原理及搭建教程
1. MyBatis MyBatis是一款优秀的持久层框架,它支持自定义 SQL.存储过程以及高级映射.MyBatis 免除了几乎所有的 JDBC 代码以及设置参数和获取结果集的工作.MyBatis ...
- (Mybatis)Mybatis简介和初步使用
1. Mybatis简介 1.1什么是Mybatis MyBatis 是一款优秀的持久层框架 它支持定制化 SQL.存储过程以及高级映射. MyBatis 避免了几乎所有的 JDBC 代码和手动设置参 ...
- MyBatis(三)MyBatis缓存和工作原理
MyBatis缓存 MyBatis提供了一级缓存和二级缓存,并且预留了集成第三方缓存的接口. 从上面MyBatis的包结构可以很容易看出跟缓存相关的类都在cache的package里,其底层是一个Ca ...
- MyBatis(一)MyBatis介绍和配置详解
在Java程序里面去操作数据库,最原始的办法是使用JDBC的API.需要分为六步: 注册驱动 通过DriverManager获取一个Connection 通过Connection创建一个Stateme ...
- MyBatis(二)MyBatis基本流程源码分析
MyBatis体系结构 MyBatis的工作流程 在MyBatis启动的时候我们要去解析配置文件,包括全局配置文件和映射器配置文件,我们会把它们解析成一个Configuration对象,里面会包含各种 ...
- 【MyBatis】MyBatis初体验
文章目录 框架 软件开发三层结构 MyBatis概念 MyBatis由来 ORM框架与MyBatis的区别 MyBatis编码流程 框架 是一个可以重复使用的设计构件,我们在做开发的时候框架是直接调来 ...
- MyBatis】MyBatis一级缓存和二级缓存
转载自 MyBatis]MyBatis一级缓存和二级缓存 MyBatis自带的缓存有一级缓存和二级缓存 一级缓存 Mybatis的一级缓存是指Session缓存.一级缓存的作用域默认是一个SqlSe ...
最新文章
- vim中权限不足时不用退出而强制保存
- Java日常开发的21个坑,你踩过几个?
- 【Android 逆向】x86 汇编 ( push / pop 入栈 / 出栈 指令 | ret / retn 函数调用返回指令 | set 设置目标值指令 )
- 读《构建之法》第4章有感
- UA OPTI570 量子力学21 Atom Trapping
- 华字后面配什么字比较好_涟字女孩取名字含义 带涟好名推荐
- 安装memcached服务 和 php 安装memcache扩展
- 35/100. Permutations
- android 面试题(一)
- 实现BUG自动检测 - ASP.NET Core依赖注入
- C++泛型编程实现二叉搜索树BST
- Android自定义View构造函数详解
- python中有readall吗_在python中使用tn.read_all()读取数据
- Yii Framework2.0开发教程(5)数据库mysql函数
- Android设置标题栏图标
- MacOS开发-给自己的 app 添加 URL Scheme(Xcode 9之后)
- Qt 中Socket编程实例
- 批量发短信的平台浏览总结
- 微软苏州研发人员将达4500人!第二幢楼今天开建!
- WTS考勤系统报表实现原理