spring boot 多对多关系中添加数据的接口_Spring Boot 2.X(二):集成 MyBatis 数据层开发

bc2e4059-abfc-4557-84d9-fd657d8d8907

MyBatis 简介


概述

MyBatis 是一款优秀的持久层框架,支持定制化 SQL、存储过程以及高级映射。它采用面向对象编程的方式对数据库进行 CRUD 的操作,使程序中对关系数据库的操作更方便简单。它支持 XML 描述符配置文件和注解两种方式执行 SQL 语句。“简单灵活”是它在对象关系映射工具上的最大优势。

mybatis-spring-boot-starter

过去使用 MyBatis 开发,需要各种配置文件、实体类、Dao 层映射关联、还有一大推其它配置。经过进行不断的优化后,终于他来了,mybatis-spring-boot-starter 可以做到无需配置只用注解开发,也可以使用简单的配置轻松上手。当然两种方式都需要在 POM 文件引入mybatis-spring-boot-starter:

org.mybatis.spring.boot    mybatis-spring-boot-starter    2.1.0

集成 MyBatis


准备工作

1.构建一个 Spring Boot项目

2.建立 MySQL 数据库(db_test),创建表(t_user)及添加部分测试数据

SET NAMES utf8mb4;SET FOREIGN_KEY_CHECKS = 0;-- ------------------------------ Table structure for t_user-- ----------------------------DROP TABLE IF EXISTS `t_user`;CREATE TABLE `t_user` (  `id` int(8) NOT NULL AUTO_INCREMENT COMMENT 'ID',  `user_name` varchar(20) CHARACTER SET utf8 COLLATE utf8_general_ci DEFAULT NULL COMMENT '用户姓名',  `user_sex` char(1) CHARACTER SET utf8 COLLATE utf8_general_ci DEFAULT NULL COMMENT '用户性别',  PRIMARY KEY (`id`)) ENGINE=InnoDB AUTO_INCREMENT=23 DEFAULT CHARSET=utf8;-- ------------------------------ Records of t_user-- ----------------------------BEGIN;INSERT INTO `t_user` VALUES (1, '刘备', '男');INSERT INTO `t_user` VALUES (2, '孙尚香', '女');INSERT INTO `t_user` VALUES (3, '周瑜', '男');INSERT INTO `t_user` VALUES (4, '小乔', '女');INSERT INTO `t_user` VALUES (5, '诸葛亮', '男');INSERT INTO `t_user` VALUES (6, '黄月英', '女');INSERT INTO `t_user` VALUES (7, '关羽', '男');INSERT INTO `t_user` VALUES (8, '张飞', '男');INSERT INTO `t_user` VALUES (9, '赵云', '男');INSERT INTO `t_user` VALUES (10, '黄总', '男');INSERT INTO `t_user` VALUES (11, '曹操', '男');INSERT INTO `t_user` VALUES (12, '司马懿', '男');INSERT INTO `t_user` VALUES (13, '貂蝉', '女');INSERT INTO `t_user` VALUES (14, '吕布', '男');INSERT INTO `t_user` VALUES (15, '马超', '男');INSERT INTO `t_user` VALUES (16, '魏延', '男');INSERT INTO `t_user` VALUES (17, '孟获', '男');INSERT INTO `t_user` VALUES (18, '大乔', '女');INSERT INTO `t_user` VALUES (19, '刘婵', '男');INSERT INTO `t_user` VALUES (20, '姜维', '男');INSERT INTO `t_user` VALUES (21, '廖化', '男');INSERT INTO `t_user` VALUES (22, '关平', '男');COMMIT;SET FOREIGN_KEY_CHECKS = 1;

3.新建用户实体类 UserEntity.java

public class UserEntity {    private Long id;    private String userName;    private String userSex;    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 getUserSex() {        return userSex;    }    public void setUserSex(String userSex) {        this.userSex = userSex;    }    }

注解方式

1.添加相关 Maven 依赖

org.springframework.boot            spring-boot-starter-web        org.springframework.boot            spring-boot-starter-test            testorg.springframework.boot            spring-boot-starter-jdbc        org.springframework.boot            spring-boot-devtools            truemysql            mysql-connector-java            runtimeorg.mybatis.spring.boot            mybatis-spring-boot-starter            2.1.0

2.application.properties 添加相关配置

#datasourcespring.datasource.driver-class-name=com.mysql.jdbc.Driverspring.datasource.url=jdbc:mysql://127.0.0.1:3306/db_test?useUnicode=true&characterEncoding=UTF-8&useSSL=truespring.datasource.username=rootspring.datasource.password=root

在启动类中添加对 mapper 包扫描@MapperScan

@SpringBootApplication@MapperScan("cn.zwqh.springboot.dao")public class SpringBootMybatisApplication {    public static void main(String[] args) {        SpringApplication.run(SpringBootMybatisApplication.class, args);    }}

或者直接在 Mapper 类上面添加注解@Mapper,建议使用上面那种,不然每个 mapper 加个注解也挺麻烦的

3.Mapper 开发

public interface UserDao {    //使用注解方式    /**     * 获取所有用户     * @return     */    @Select("select * from t_user")    @Results({        @Result(property = "userName",column = "user_name"),        @Result(property = "userSex",column = "user_sex")    })    List getAll2();    /**     * 根据id获取用户     * @param id     * @return     */    @Select("select * from t_user where id=#{id}")    @Results({        @Result(property = "userName",column = "user_name"),        @Result(property = "userSex",column = "user_sex")    })    List getOne2(Long id);    /**     * 新增用户     * @param user     */    @Insert("insert into t_user (user_name,user_sex) values(#{userName},#{userSex})")    void insertUser2(UserEntity user);    /**     * 修改用户     * @param user     */    @Update("update t_user set user_name=#{userName},user_sex=#{userSex} where id=#{id}")    void updateUser2(UserEntity user);    /**     * 删除用户     * @param id     */    @Delete("delete from t_user where id=#{id}")    void deleteUser2(Long id);}

注解:@Select 是查询类的注解,所有的查询均使用这个@Result 修饰返回的结果集,关联实体类属性和数据库字段一一对应,如果实体类属性和数据库属性名保持一致,就不需要这个属性来修饰。@Insert 插入数据库使用,直接传入实体类会自动解析属性到对应的值@Update 负责修改,也可以直接传入对象@delete 负责删除

4. restful 接口测试

UserController

@RestController@RequestMapping("/user")public class UserController {        @Autowired    private UserDao userDao;            //使用注解方式    /**     * 获取所有用户     * @return     */    @RequestMapping("/getAll2")    public List getAll2(){        return userDao.getAll2();     }    /**     * 根据id获取用户     * @return     */    @RequestMapping("/getOne2")    public List getOne2(Long id){        return userDao.getOne2(id);     }    /**     * 新增用户     * @param user     * @return     */    @RequestMapping("/insertUser2")    public String insertUser2(UserEntity user) {        userDao.insertUser2(user);        return "insert success";    }        /**     * 修改用户     * @param user     * @return     */    @RequestMapping("/updateUser2")    public String updateUser2(UserEntity user) {        userDao.updateUser2(user);        return "update success";    }    /**     * 删除用户     * @param user     * @return     */    @RequestMapping("/deleteUser2")    public String deleteUser2(Long id) {        userDao.deleteUser2(id);        return "delete success";    }        }

启动项目后可以通过浏览器访问 http://127.0.0.1:8080/user/getOne2?id=1 进行测试,其他雷同。也可以编写单元测试进行测试。

XML 方式

1.pom 文件如上

2.application.properties 添加相关配置

#datasourcespring.datasource.driver-class-name=com.mysql.jdbc.Driverspring.datasource.url=jdbc:mysql://127.0.0.1:3306/db_test?useUnicode=true&characterEncoding=UTF-8&useSSL=truespring.datasource.username=rootspring.datasource.password=root#mybatismybatis.mapper-locations=classpath:/mapper/*.xml

3.Mapper 层开发

public interface UserDao {    //mapper.xml方式     /**     * 获取所有用户     * @return     */    List getAll();    /**     * 根据id获取用户     * @return     */    List getOne(Long id);    /**     * 新增用户     * @param user     */    void insertUser(UserEntity user);    /**     * 修改用户     * @param user     */    void updateUser(UserEntity user);    /**     * 删除用户     * @param id     */    void deleteUser(Long id);}

4.xml 映射文件

<?xml version="1.0" encoding="UTF-8"?>        select * from t_user            select * from t_user where id=#{id}            insert into t_user (user_name,user_sex) values(#{userName},#{userSex})            update t_user set user_name=#{userName},user_sex=#{userSex} where id=#{id}            delete from t_user where id=#{id}    

如何选择使用

个人觉得,注解方式适合轻量级的项目,现在的微服务项目比较适合这种模式;对于大型项目,复杂的多表联合查询sql用 xml 更适合。

扩展: 使用 MyBatis 分页插件 pagehelper

1. pom.xml 添加依赖

        com.github.pagehelper            pagehelper-spring-boot-starter            1.2.12

2. pagehelper 使用

@RestController@RequestMapping("/user")public class UserController {        @Autowired    private UserDao userDao;    /**     * 使用pagehelper分页插件     * @param pageNum     * @param pageSize     * @return     */    @RequestMapping("/pagehelperTest")    public List pagehelperTest(int pageNum,int pageSize){        PageHelper.startPage(pageNum, pageSize);        return userDao.getAll(); //直接使用上面的 mapper     }}

3. 测试

浏览器直接访问 http://127.0.0.1:8080/user/pagehelperTest?pageNum=1&pageSize=10 ,改变参数试试。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值