IT俱乐部 Java Java中的List和MySQL中的varchar相互转换的解决方案

Java中的List和MySQL中的varchar相互转换的解决方案

需求

实体类中有一个 List 类型的属性,对应于 MySQL 表里的 varchar 字段,使用 MyBatis 添加或查询时能互相转换。

解决方案

自定义一个类型处理器:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
package com.examples.handler;
 
import org.apache.ibatis.type.BaseTypeHandler;
import org.apache.ibatis.type.JdbcType;
 
import java.sql.CallableStatement;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;
 
public class ListStringTypeHandler extends BaseTypeHandler> {
 
    @Override
    public void setNonNullParameter(PreparedStatement ps, int i, List parameter, JdbcType jdbcType) throws SQLException {
        ps.setString(i, String.join(",", parameter));
    }
 
    @Override
    public List getNullableResult(ResultSet rs, String columnName) throws SQLException {
        if (rs.getString(columnName) == null) {
            return new ArrayList();
        }
        return Arrays.asList(rs.getString(columnName).split(","));
    }
 
    @Override
    public List getNullableResult(ResultSet rs, int columnIndex) throws SQLException {
        if (rs.getString(columnIndex) == null) {
            return new ArrayList();
        }
        return Arrays.asList(rs.getString(columnIndex).split(","));
    }
 
    @Override
    public List getNullableResult(CallableStatement cs, int columnIndex) throws SQLException {
        if (cs.getString(columnIndex) == null) {
            return new ArrayList();
        }
        return Arrays.asList(cs.getString(columnIndex).split(","));
    }
}

示例

Java 实体类

1
2
3
4
5
6
@Data
public class Student {
    private Long id;
    private String name;
    private List hobbies;
}

数据表的字段

Mapper接口

1
2
3
4
5
public interface StudentMapper {
    void saveStudent(Student student);
 
    Student queryStudentById(long id);
}

xml文件 需要使用 typeHandler=”com.examples.handler.ListStringTypeHandler”

1
2
3
4
5
6
insert into student (name, hobbies)
values (#{name}, #{hobbies,typeHandler=com.examples.handler.ListStringTypeHandler})
 
select *
from student
where id = #{id}

测试

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
public class StudentTest {
 
    @Resource
    private StudentMapper studentMapper;
 
    // 添加
    @Test
    void testSaveStudent() {
        Student student = new Student();
        List hobbiesList = new ArrayList();
        hobbiesList.add("篮球");
        hobbiesList.add("阅读");
        hobbiesList.add("写代码");
 
        student.setName("张三");
        student.setHobbies(hobbiesList);
        studentMapper.saveStudent(student);
    }
 
    //查询
    @Test
    void testQueryStudentById() {
        Student student = studentMapper.queryStudentById(1L);
        System.out.println(student);
    }
}

添加的结果

查询的结果

到此这篇关于Java中的List和MySQL中的varchar相互转换的解决方案的文章就介绍到这了,更多相关Java List和MySQL varchar相互转换内容请搜索IT俱乐部以前的文章或继续浏览下面的相关文章希望大家以后多多支持IT俱乐部!

本文收集自网络,不代表IT俱乐部立场,转载请注明出处。https://www.2it.club/code/java/11882.html
上一篇
下一篇
联系我们

联系我们

在线咨询: QQ交谈

邮箱: 1120393934@qq.com

工作时间:周一至周五,9:00-17:30,节假日休息

关注微信
微信扫一扫关注我们

微信扫一扫关注我们

返回顶部