本章主要讲述Mybatis与Mybatis-Plus整合
MyBatis-Plus(简称 MP)是一个 MyBatis 的增强工具,在 MyBatis 的基础上只做增强不做改变,为简化开发、提高效率而生。
官网:https://mybatis.plus/ 或 https://mp.baomidou.com/
-- 创建测试表
CREATE TABLE `tb_user` (
`id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '主键ID',
`user_name` varchar(20) NOT NULL COMMENT '用户名',
`password` varchar(20) NOT NULL COMMENT '密码',
`name` varchar(30) DEFAULT NULL COMMENT '姓名',
`age` int(11) DEFAULT NULL COMMENT '年龄',
`email` varchar(50) DEFAULT NULL COMMENT '邮箱',
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8;
-- 插入测试数据
INSERT INTO `tb_user` (`id`, `user_name`, `password`, `name`, `age`, `email`) VALUES
('1', 'zhangsan', '123456', '张三', '18', '[email protected]');
INSERT INTO `tb_user` (`id`, `user_name`, `password`, `name`, `age`, `email`) VALUES
('2', 'lisi', '123456', '李四', '20', '[email protected]');
INSERT INTO `tb_user` (`id`, `user_name`, `password`, `name`, `age`, `email`) VALUES
('3', 'wangwu', '123456', '王五', '28', '[email protected]');
INSERT INTO `tb_user` (`id`, `user_name`, `password`, `name`, `age`, `email`) VALUES
('4', 'zhaoliu', '123456', '赵六', '21', '[email protected]');
INSERT INTO `tb_user` (`id`, `user_name`, `password`, `name`, `age`, `email`) VALUES
('5', 'sunqi', '123456', '孙七', '24', '[email protected]');
4.0.0
cn.mikasa.mp
mikasa-mybatis-plus
pom
1.0-SNAPSHOT
cn-mikasa-mp
mikasa-mybatis-plus-spring
com.baomidou
mybatis-plus
3.1.1
mysql
mysql-connector-java
5.1.46
com.alibaba
druid
1.1.6
org.projectlombok
lombok
1.16.22
junit
junit
4.12
org.slf4j
slf4j-log4j12
1.6.4
org.apache.maven.plugins
maven-compiler-plugin
1.8
1.8
mikasa-mybatis-plus
cn.mikasa.mp
1.0-SNAPSHOT
4.0.0
cn.mikasa.mp
cn-mikasa-mp
log4j.rootLogger=DEBUG,A1
log4j.appender.A1=org.apache.log4j.ConsoleAppender
log4j.appender.A1.layout=org.apache.log4j.PatternLayout
log4j.appender.A1.layout.ConversionPattern=[%t] [%c]-[%p] %m%n
package cn.mikasa.mp.pojo;
import com.baomidou.mybatisplus.annotation.TableName;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
@Data
@NoArgsConstructor
@AllArgsConstructor
@TableName("tb_user")
public class User {
private Long id;
private String username;
private String password;
private String name;
private Integer age;
private String email;
}
package com.mikasa.mp.mapper;
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.mikasa.mp.pojo.User;
public interface UserMapper extends BaseMapper {
}
package cn.mikasa.mp;
import cn.mikasa.mp.mapper.UserMapper;
import cn.mikasa.mp.pojo.User;
import com.baomidou.mybatisplus.core.MybatisSqlSessionFactoryBuilder;
import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.junit.Test;
import java.io.IOException;
import java.io.InputStream;
import java.util.List;
//mybatis + mp
public class TestMybatisPlus {
@Test
public void testFindAll() throws IOException {
InputStream inputStream = Resources.getResourceAsStream("mybatis-config.xml");
//注意这里用的是mybatisSqlSessionFactoryBuilder
SqlSessionFactory sessionFactory = new MybatisSqlSessionFactoryBuilder().build(inputStream);
SqlSession sqlSession = sessionFactory.openSession();
UserMapper userMapper = sqlSession.getMapper(UserMapper.class);
List list = userMapper.findAll();
for (User user : list) {
System.out.println(user);
}
}
}