前端需要Json,数据库是varchar,java后端怎么设计

技术背景:

Json用的jackson,ORM框架用的hibernate-jpa

<!-- https://mvnrepository.com/artifact/com.fasterxml.jackson.core/jackson-annotations -->  
<dependency>  
    <groupId>com.fasterxml.jackson.core</groupId>  
    <artifactId>jackson-annotations</artifactId>  
    <version>2.9.0</version>  
</dependency>  
  
<!-- https://mvnrepository.com/artifact/org.hibernate.javax.persistence/hibernate-jpa-2.1-api -->  
<dependency>  
    <groupId>org.hibernate.javax.persistence</groupId>  
    <artifactId>hibernate-jpa-2.1-api</artifactId>  
    <version>1.0.0.Final</version>  
</dependency>

需求:

最近做需求,前端一个对象需要新增一个List<String>的字段,后端传给前端的是json,Json序列化对应的实体类刚好也是映射数据库的实体类
大概如下:

@Entity
@Table(name = "tb_user")
@JsonIgnoreProperties(ignoreUnknown = true)
public class User {
	// columns...
	// 需要新增的字段
	@Column(name = "names")
	private List<String> names;
}

数据库新增的字段是names,类型是varchar,如果就这样启动项目,会报错,字段类型不匹配。

解决方案

Hibernate有一个接口AttributeConverter<X, Y>,实现这个接口,可以在映射时,自动地将Entity 类的X类型转成与数据库对应的Y类型。
具体代码如下

image.png

这里做实现:

import javax.persistence.AttributeConverter;  
import java.util.List;  

// @Converter注解其中可以设置是否全局生效,默认false
@Converter
public class StrList2JsonConverter implements AttributeConverter<List<String>, String> {  
  
    @Override  
    public String convertToDatabaseColumn(List<String> strings) {  
//        将List<String>转Json  
        return null;  
    }  
  
    @Override  
    public List<String> convertToEntityAttribute(String s) {  
//        将Json转List<String>  
        return null;  
    }  
}

此外,还需要在实体类的字段上加上注解,表明要使用这个converter

	@Column(name = "names")
	@Convert(converter = StrList2JsonConverter.class)
	private List<String> names;

至此实现目标效果

最后附上,个人博客网站:Southblock’Blog,内容更多,更新,欢迎参观。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值