5、springcloud整合mybatis注解方式

简介: 本篇内容学习springcloud整合mybatis注解方式。

上一篇学习了服务提供者provider,但是并不是单单就学习了服务提供者。中间还穿插使用了Hikari数据源和spring cloud整合mybatis。但是上篇使用mybatis时还是沿用了老的方式,需要配置mapper对应的xml文件。


1、先来看看上篇使用mybatis的主要步骤


一、 pom.xml文件引用


<dependency>
        <groupId>org.mybatis</groupId>
        <artifactId>mybatis-spring</artifactId>
        <version>1.3.2</version>
      </dependency>
      <dependency>
        <groupId>org.mybatis.spring.boot</groupId>
        <artifactId>mybatis-spring-boot-starter</artifactId>
        <version>1.3.2</version>
    </dependency>


二、application.yml配置文件加入mybtias配置项


mybatis:
  mapperLocations: classpath:sc/provider/dao/*.xml
  #configLocation: classpath:mybatis-config.xml


三、编写mapper文件user-mapper.xml


<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd" >
<mapper namespace="sc.provider.dao.UserDao" >
   <select id="getUser" parameterType="java.lang.Long"  resultType="sc.provider.model.User">
      select id, userName, age, position from t_user where id = #{id,jdbcType=INTEGER}
   </select>
   <select id="listUser" resultType="sc.provider.model.User">
      select id, userName, age, position from t_user
   </select>
   <insert id="addUser" parameterType="sc.provider.model.User">
      insert into t_user (
         id, userName, age, position
      ) values (
         #{id,jdbcType=INTEGER},
         #{userName,jdbcType=VARCHAR},
         #{age,jdbcType=INTEGER},
         #{position,jdbcType=VARCHAR}
      )
   </insert>
   <update id="updateUser" parameterType="sc.provider.model.User">
        update t_user set
         userName = #{userName,jdbcType=VARCHAR},
         age = #{age,jdbcType=INTEGER},
         position = #{position,jdbcType=VARCHAR}
        where id = #{id,jdbcType=INTEGER}
   </update>
   <delete id="deleteUser" parameterType="java.lang.Long">
    delete from t_user
      where id = #{id,jdbcType=INTEGER}
   </delete>
</mapper>


四、编写UserDao.java


package sc.provider.dao;
import java.util.List;
import sc.provider.model.User;
public interface UserDao {
   User getUser(Long id);
   List<User> listUser();
   int addUser(User user);
   int updateUser(User user);
   int deleteUser(Long id);
}


五、 在ProviderApplication.java添加@MapperScan(basePackages="sc.provider.dao")


经过上面五个步骤才能使用mybatis。本篇将和大家看看不能简化spring cloud 整合mybatis的步骤(在sc-eureka-client-provider工程上改造)


一、 依赖必不可少


<dependency>
        <groupId>org.mybatis</groupId>
        <artifactId>mybatis-spring</artifactId>
        <version>1.3.2</version>
      </dependency>
      <dependency>
        <groupId>org.mybatis.spring.boot</groupId>
        <artifactId>mybatis-spring-boot-starter</artifactId>
        <version>1.3.2</version>
    </dependency>


二、 删除application.yml关于mybatis的配置


三、 删除mapper文件user-mapper.xml文件


四、改造UserDao.java类


package sc.provider.dao;
import java.util.List;
import org.apache.ibatis.annotations.Delete;
import org.apache.ibatis.annotations.Insert;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Select;
import org.apache.ibatis.annotations.Update;
import sc.provider.model.User;
@Mapper
public interface UserDao {
   @Select(value="select id, userName, age, position from t_user where id = #{id,jdbcType=INTEGER}")
   User getUser(Long id);
   @Select(value="select id, userName, age, position from t_user")
   List<User> listUser();
   @Insert(value="insert into t_user (id, userName, age, position) values ( #{id,jdbcType=INTEGER},#{userName,jdbcType=VARCHAR},#{age,jdbcType=INTEGER},#{position,jdbcType=VARCHAR})")
   int addUser(User user);
   @Update(value="update t_user set userName = #{userName,jdbcType=VARCHAR},age = #{age,jdbcType=INTEGER},position = #{position,jdbcType=VARCHAR} where id = #{id,jdbcType=INTEGER}")
   int updateUser(User user);
   @Delete(value=" delete from t_user where id = #{id,jdbcType=INTEGER}")
   int deleteUser(Long id);
}


五、 @MapperScan注解必不可少


package sc.provider;
import org.mybatis.spring.annotation.MapperScan;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.netflix.eureka.EnableEurekaClient;
@SpringBootApplication
@EnableEurekaClient
@MapperScan(basePackages="sc.provider.dao")
public class ProviderApplication {
   public static void main(String[] args) {
      SpringApplication.run(ProviderApplication.class, args);
   }
}


经过以上步骤就把使用xml方式的mybatis改造成使用annotation方式的mybatis了。


2、启动注册中心sc-eureka-server,启动sc-eureka-client-provider-annotation(使用sc-eureka-client-provider项目改造),验证是否改造成功


方式一:


微信图片_20220501130115.png


方法二:


微信图片_20220501130118.png


圈住的名字是在application.yml配置的


微信图片_20220501130121.png


3、使用postman方法相应restful接口,这里就不一一访问了,可以参考上一篇文章的访问方式


添加:


http://127.0.0.1:8300/user/addUser


查询:


http://127.0.0.1:8300/user/getUser/4


列表:


http://127.0.0.1:8300/user/listUser


更新:


http://127.0.0.1:8300/user/updateUser


删除:


http://127.0.0.1:8300/user/deleteUser/2

相关文章
|
5天前
|
SQL Java 数据库连接
【MyBatisPlus·最新教程】包含多个改造案例,常用注解、条件构造器、代码生成、静态工具、类型处理器、分页插件、自动填充字段
MyBatis-Plus是一个MyBatis的增强工具,在 MyBatis 的基础上只做增强不做改变,为简化开发、提高效率而生。本文讲解了最新版MP的使用教程,包含多个改造案例,常用注解、条件构造器、代码生成、静态工具、类型处理器、分页插件、自动填充字段等核心功能。
【MyBatisPlus·最新教程】包含多个改造案例,常用注解、条件构造器、代码生成、静态工具、类型处理器、分页插件、自动填充字段
|
15天前
|
SQL 缓存 Java
MyBatis如何关闭一级缓存(分注解和xml两种方式)
MyBatis如何关闭一级缓存(分注解和xml两种方式)
43 5
|
15天前
|
Java 数据库连接 mybatis
Mybatis使用注解方式实现批量更新、批量新增
Mybatis使用注解方式实现批量更新、批量新增
36 3
|
22天前
|
SQL 存储 数据库
深入理解@TableField注解的使用-MybatisPlus教程
`@TableField`注解在MyBatis-Plus中是一个非常灵活和强大的工具,能够帮助开发者精细控制实体类与数据库表字段之间的映射关系。通过合理使用 `@TableField`注解,可以实现字段名称映射、自动填充、条件查询以及自定义类型处理等高级功能。这些功能在实际开发中,可以显著提高代码的可读性和维护性。如果需要进一步优化和管理你的MyBatis-Plus应用程
97 3
|
20天前
|
Java 数据库连接 mybatis
Mybatis使用注解方式实现批量更新、批量新增
Mybatis使用注解方式实现批量更新、批量新增
39 1
|
2月前
|
SQL XML Java
mybatis复习02,简单的增删改查,@Param注解多个参数,resultType与resultMap的区别,#{}预编译参数
文章介绍了MyBatis的简单增删改查操作,包括创建数据表、实体类、配置文件、Mapper接口及其XML文件,并解释了`#{}`预编译参数和`@Param`注解的使用。同时,还涵盖了resultType与resultMap的区别,并提供了完整的代码实例和测试用例。
mybatis复习02,简单的增删改查,@Param注解多个参数,resultType与resultMap的区别,#{}预编译参数
|
2月前
|
Java 数据库连接 数据格式
【Java笔记+踩坑】Spring基础2——IOC,DI注解开发、整合Mybatis,Junit
IOC/DI配置管理DruidDataSource和properties、核心容器的创建、获取bean的方式、spring注解开发、注解开发管理第三方bean、Spring整合Mybatis和Junit
【Java笔记+踩坑】Spring基础2——IOC,DI注解开发、整合Mybatis,Junit
WXM
|
3月前
|
存储 缓存 Java
|
3月前
|
SQL Java 数据库
5、Mybatis-Plus 常用注解
这篇文章详细介绍了Mybatis-Plus中常用的注解,包括解决实体类与数据库表名不一致、字段不匹配的问题,主键生成策略的配置,以及逻辑删除的实现方法。
5、Mybatis-Plus 常用注解
WXM
|
3月前
|
前端开发 程序员