12、Spring Boot整合通用Mapper

目标:配置通用Mapper组件到Sringboot项目并使用Mapper接口

分析:
通用Mapper:可以实现自动拼接sql语句;所有mapper都不需要编写任何方法也就是不用编写sql语句,所以提高开发效率。
1、添加启动器依赖

  <!--通用mapper-->
        <dependency>
            <groupId>tk.mybatis</groupId>
            <artifactId>mapper-spring-boot-starter</artifactId>
            <version>2.1.5</version>
        </dependency>

2、改造UserMapper继承Mapper< User>

public interface UserMapper extends Mapper<User> {
}

3、修改启动引导类application中的Mapper扫描注解
(用的是tk开头的MapperScan)

//这个是自己加的通用mapper
@MapperScan("com.mapper")
public class Application {
    public static void main(String[] args) {
        SpringApplication.run(Application.class,args);
    }
}

4、修改User实体类添加jpa注解

@Data//在编译阶段会根据注解自动生成对应的方法;data包含get/set/hashCode/equals/toString等方法
@Table(name = "tb_user")
public class User {
    @Id
    //主键回值
    @KeySql(useGeneratedKeys = true)//设置主键
    private Long id;

    @Column//这个是为了将数据命名和数据库中的可以规则话,一般都是和数据库一样的
    //user_name-->userName
    private String username;

    private String password;

    private String name;

    private Integer age;

    private Integer sex;

    private Date brithday;

    private String note;

    private Date created;
}

5、修饰UserService实现业务功能

@Service
public class UserService {

    @Autowired
    private UserMapper userMapper;
    //根据id查询
    public User queryById(Long id){
        return userMapper.selectByPrimaryKey(id);
    }
    //新增保存用户
    @Transactional
   public void saveService(User user){
        System.out.println("新用户.....");
         //选择性新增:如果属性为空则该属性不会出现在insert语句上
        userMapper.insertSelective(user);
    }
}

总结;
在启动类上面的mapper注解,一定要改为通用mapper的注解

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值