在PostgreSQL中将bytea转换为双精度

在PostgreSQL中将bytea转换为双精度,第1张

概述我有一个数据库,其中一个表存储从另一个系统收集的各种通用数据的blob(bytea). bytea字段中可以包含任何内容.为了解如何解释数据,该表还具有格式字段.我编写了一个 Java应用程序来读取数据库中的bytea字段作为byte []然后我可以通过使用ByteBuffer和各种视图(DoubleBuffer,IntBuffer)轻松地将其转换为double []或int []或者格式字段所说 我有一个数据库,其中一个表存储从另一个系统收集的各种通用数据的blob(bytea). bytea字段中可以包含任何内容.为了解如何解释数据,该表还具有格式字段.我编写了一个 Java应用程序来读取数据库中的bytea字段作为byte []然后我可以通过使用ByteBuffer和各种视图(DoubleBuffer,IntBuffer)轻松地将其转换为double []或int []或者格式字段所说的任何内容.等).

现在,我需要在触发器函数中对数据库本身的数据进行一些 *** 作,以便与另一个表保持完整性.我可以找到几乎任何可以想象的数据类型的转换,但是我找不到从bytea(或偶数位)到双精度和返回的任何东西. bytea可以被分解,转换为位,然后转换为int或bigint,但不是双精度.例如,x’deadbeefdeadbeef’:: bit(64):: bigint将转换为-2401053088876216593没有问题,但是x’deadbeefdeadbeef’:: bit(64):: double precision失败并出现“ERROR:无法将类型转换为双精度“而不是给出IEEE的754答案-1.1885959257070704E148.

我找到了这个答案https://stackoverflow.com/a/11661849/5274457,它基本上实现了IEEE标准,将位转换为double,但是在Postgresql中真的没有基本的转换函数吗?另外,当我完成 *** 作数据并需要更新表时,我还需要从双精度到字节向后,这个答案没有提供.

有任何想法吗?

好的,我找到了答案.在Postgresql中,您可以使用Python编写函数.为了能够使用Python,您必须安装Postgresql安装所需的特定版本的Python,并在PATH环境变量中使用它.通过查看安装说明,您可以找到Postgresql安装所需的Python版本.我目前在windows上使用Postgresql 9.6.5,它需要Python 3.3.我最初尝试了最新的Python 3.6,但它不起作用.我决定使用最新的Python 3.3 for windows,即3.3.5.

安装Python后,通过执行CREATE EXTENSION plpython3u在Postgresql中启用它;在您的数据库中,如此处所述https://www.postgresql.org/docs/current/static/plpython.html.从那里,您可以使用Python主体编写任何函数.

对于我从bytea转换为double precision []并返回的特定情况,我编写了以下函数:

CREATE FUNCTION bytea_to_double_array(b bytea)    RETURNS double precision[]    LANGUAGE 'plpython3u'AS $BODY$  if 'struct' in GD:    struct = GD['struct']  else:    import struct    GD['struct'] = struct  return struct.unpack('<' + str(int(len(b) / 8)) + 'd',b)$BODY$;CREATE FUNCTION double_array_to_bytea(dblarray double precision[])    RETURNS bytea    LANGUAGE 'plpython3u'AS $BODY$  if 'struct' in GD:    struct = GD['struct']  else:    import struct    GD['struct'] = struct  # dblarray here is really a List.  # Postgresql passes sql arrays as Python Lists  return struct.pack('<' + str(int(len(dblarray))) + 'd',*dblarray)$BODY$;

在我的情况下,所有的双打都存储在小端,所以我使用<.我还在https://stackoverflow.com/a/15025425/5274457中描述了在全局字典中缓存struct模块的导入.我使用GD而不是SD,因为我想在我可能编写的其他函数中使用导入.有关GD和SD的信息,请参阅https://www.postgresql.org/docs/current/static/plpython-sharing.html.

要知道我的数据库中的blob存储为小端,要查看它的运行情况,

SELECT bytea_to_double_array(decode('efbeaddeefbeadde','hex')),encode(double_array_to_bytea(array[-1.1885959257070704E148]),'hex');

我得到的答案是

bytea_to_double_array    | encodedouble precision[]       | text-------------------------+------------------{-1.18859592570707e+148} | efbeaddeefbeadde

其中’efbeaddeefbeadde’是小端的’deadbeefdeadbeef’.

总结

以上是内存溢出为你收集整理的在PostgreSQL中将bytea转换为双精度全部内容,希望文章能够帮你解决在PostgreSQL中将bytea转换为双精度所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/sjk/1181785.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2022-06-02
下一篇2022-06-02

发表评论

登录后才能评论

评论列表(0条)

    保存