关于通用Mapper中 @Transient注解的使用 (何时需要使用,何时不用)

问题发现

在写安卓程序的过程中,需要传递一个username 到 服务端,但是每个@PostMapping对应的方法都写String username 过于麻烦,于是直接在 对应的类中增加了一个属性 String username 以及 Get、Set,但是 随即执行插入的时候报了这个错
Error querying database. Cause: com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException: Unknown column ‘username’ in ‘field list’
之前一直以为 通用Mapper 只扫描 @Column 注解的属性, 现在看来并不是

解决方式

更改 username属性为
注 — 该有两个包有同名注解,应该使用javax.persistence包下的

   @Transient
    private String username ;

即可
那为什么以前写一对多的关系的时候并没有把 对应的属性扫描进去呢?
解答-> 往常写的一对多 类似于这个


@Table(name = "`title`")
public class Title {
    @Id
    @Column(name = "`Id`")
    @GeneratedValue(generator = "JDBC")
    private Integer id;

    private Content content;

这种 情况下 insert 语句并不会出错
出错的是这样的

@Table(name = "`title`")
public class Title {
    @Id
    @Column(name = "`Id`")
    @GeneratedValue(generator = "JDBC")
    private Integer id;


//    private String username ;

总结

显而易见 , String 以及基本数据类型 是会被默认扫描进去的,无论你有没有注解@Column ,


因此,如果 你自定义属性 为String 或者基本数据类型 则需要使用@Transient 注解 ,而如果自定义字段是引用类型则不需要使用该注解

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: @Mapper注解用于标记一个接口,它表示这个接口将作为MyBatis的映射文件来使用,它对应一个XML文件,其定义了将被映射到该接口的SQL语句。@Repository注解是用来标识DAO层的组件,它将被用于自动生成DAO实现类,以及实现持久化操作。 ### 回答2: 在Spring Boot,@Mapper和@Repository是两个常见的注解,用于在框架进行数据访问和持久化操作。 @Mapper是MyBatis框架注解,用于标识一个接口是MyBatis的映射器。通过@Mapper注解,我们可以告诉Spring Boot将这个接口注册为一个可以执行SQL语句的Mapper接口。在使用@Mapper注解时,我们无需编写接口的具体实现,MyBatis会根据接口的定义自动生成对应的实现类。这样,我们就可以通过调用Mapper接口的方法来执行数据库的增删改查等操作。 @Repository是Spring框架注解,用于标识一个类是持久化层(Repository层)的组件。在Spring Boot,我们通常使用@Repository注解将DAO(数据访问对象)标识为持久化组件。使用@Repository注解后,Spring Boot会自动扫描并将其纳入IoC容器,使得我们可以在其他组件直接使用@Autowired注解来注入并使用该持久化对象。 总结起来,@Mapper注解用于MyBatis的接口类,告诉Spring Boot将接口注册为Mapper并生成对应的实现类,使得我们可以使用Mapper接口执行数据库操作。而@Repository注解用于Spring的持久化层组件类,标识该类为数据访问对象,可以在其他组件直接进行注入和使用。这两个注解在Spring Boot起到了不同的作用,但都是用于简化数据库访问和持久化操作的配置和编码工作。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值