pgsql中处理数组类型字段

1、代码中存入和读取

需要使用自定义转换器

java 复制代码
@Slf4j
public class ArrayTypeHandler extends BaseTypeHandler<List<String>> {

    @Override
    public void setNonNullParameter(PreparedStatement ps, int i, List<String> parameter, JdbcType jdbcType)
            throws SQLException {
        Object[] objects = parameter.toArray();
        Array array = ps.getConnection().createArrayOf("varchar", objects);
        ps.setArray(i, array);
    }

    @Override
    public List<String> getNullableResult(ResultSet rs, String columnName) throws SQLException {
        return getArray(rs.getArray(columnName));
    }


    @Override
    public List<String> getNullableResult(ResultSet rs, int columnIndex) throws SQLException {
        return getArray(rs.getArray(columnIndex));
    }


    @Override
    public List<String> getNullableResult(CallableStatement cs, int columnIndex) throws SQLException {
        return getArray(cs.getArray(columnIndex));
    }

    private List<String> getArray(Array array) {

        if (array == null) {
            return null;
        }

        try {
            String[] objects = (String[]) array.getArray();
            return Arrays.asList(objects);
        } catch (SQLException e) {
            log.error("sql转换失败");
        }
        return null;
    }
}

本项目使用的ORM框架是mybatis-flex 在字段上添加注解

java 复制代码
@Column(jdbcType = JdbcType.ARRAY,typeHandler = ArrayTypeHandler.class)
    private List<String> swlToCnIds;

然后正常插入、查询即可

2、sql中使用数组属性字段

  • 使用any函数
sql 复制代码
// 是否包含
value = ANY(array)
// 是否有大于值
value > ANY(array)
// 小于同理
value < ANY(array)
// 是否有不等于的
value <> ANY(array)

any和关联查询一起使用

sql 复制代码
SELECT 
    b.*,string_agg(DISTINCT s1.name, ',' order by s1.name) as sw_to_bts,string_agg(DISTINCT s2.name,',' order by s2.name) as sw_to_cn
FROM 
    t_ne_mgr_bsc b
LEFT JOIN 
    t_ne_switch_mgr s1 ON s1.id = ANY(b.swl_to_bts_ids)
LEFT JOIN 
    t_ne_switch_mgr s2 ON s2.id = ANY(b.swl_to_cn_ids)
WHERE 
    b.removed = false
group by b.id

关联查询的结果用函数string_agg聚合 拼接成为一个新字段

(因为id是主键,因此其它列不用写在group by 里面)

相关推荐
IvorySQL4 小时前
PostgreSQL 技术日报 (6月16日)|Neon 自动化再进一步,逻辑复制冲突日志迎来 v50 更新
数据库·postgresql·自动化
倒流时光三十年4 小时前
PostgreSQL 聊一下索引和排序规则
postgresql
睡不醒男孩0308231 天前
PostgreSQL 数据库运维转型:从传统模式到 CLup 平台的 25 个核心 FAQ
运维·数据库·postgresql
JOJO数据科学1 天前
pgAdmin4 Electron 鸿蒙 PC 适配全记录:从白屏到连接 PostgreSQL
postgresql·electron·harmonyos
日取其半万世不竭1 天前
PostgreSQL 跑在 Docker 里怎么备份?恢复成功才算备份成功
数据库·docker·postgresql
倒流时光三十年1 天前
PostgreSQL LEAST 表达式函数详解
数据库·postgresql
Rain5091 天前
2.4. PostgreSQL 数据库连接与实战指南
前端·数据库·人工智能·后端·postgresql·数据分析
倒流时光三十年2 天前
PostgreSQL CASE 条件表达式详解
数据库·postgresql
倒流时光三十年2 天前
PostgreSQL COALESCE 条件表达式函数详解
数据库·postgresql
雁無痕2 天前
Postgresql启动无监听端口问题的解决
postgresql