数组 – 在PostgreSQL中将位字符串转换为数组

我有一个160个字符串的字符串,我需要一个整数数组来存储值为1的位的位置.

例:

bitstring = '00110101'
array = [3,4,6,8]

是否可以仅使用sql执行此操作,还是需要定义PL / sql函数或类似的东西?

解决方法

确实可以用sql编写它.这是一个起点:

select array(
  select substring(str from i for 1) as bit
  from generate_series(1,length(str)) as i
  where bit = '1'
);

不过,您可能希望将其包装在pl / sql函数中,以避免在整个地方重复代码.

工作功能

create or replace function get_bit_positions(varbit) returns bit[] as $$
select array(
  select substring($1 from i for 1) as bit
  from generate_series(1,length($1)) as i
  where substring($1 from i for 1) = '1'
);
$$language sql immutable;

相关文章

项目需要,有个数据需要导入,拿到手一开始以为是mysql,结果...
本文小编为大家详细介绍“怎么查看PostgreSQL数据库中所有表...
错误现象问题原因这是在远程连接时pg_hba.conf文件没有配置正...
因本地资源有限,在公共测试环境搭建了PGsql环境,从数据库本...
wamp 环境 这个提示就是说你的版本低于10了。 先打印ph...
psycopg2.OperationalError: SSL SYSCALL error: EOF detect...