我目前正在尝试在 PL/Python 中编写一个过程来执行一些数据的转换,然后将结果作为bytea
. (实际上,这很丑:在 OCaml 中编组数据!在 Python 和 OCaml 中同时出现丑陋;我应该获得奖牌吗?)
这是它的样子:
CREATE OR REPLACE FUNCTION ml_marshal(data varchar) RETURNS bytea as $$
import tempfile, os
fn = tempfile.mktemp()
f = open(fn, 'w')
dest_fn = tempfile.mktemp()
f.write("let outch = open_out_bin \"" + dest_fn + "\" in " +
"Marshal.to_channel outch (" + data + ") [Marshal.No_sharing]; " +
"close_out outch")
f.close()
os.system("ocaml " + fn)
os.unlink(fn)
f = open(dest_fn, 'r')
res = f.read()
f.close()
os.unlink(dest_fn)
return res
$$ LANGUAGE plpythonu;
简而言之,它将一个小的 OCaml 程序写入一个临时文件,该临时文件创建另一个包含我们想要的数据的临时文件。然后我们读入那个临时文件,销毁它们,然后返回结果。
只是它不太有效:
meidi=# select * from tblmodel;
modelid | polies
---------+------------------
1 | \204\225\246\276
2 | \204\225\246\276
每个有四个字节(应该有〜130)。如果我停止它取消链接文件,那么原因就很明显了;有四个非 NUL 字节,后跟几个 NUL,并且在从 Python 到 Postgres 的转换过程中,这些 NUL 似乎在某个阶段被视为终止符!
有谁知道为什么会发生这种情况,或者如何阻止它?文档没有启发性。
谢谢!
编辑:我发现其他人有同样的问题,但解决方案相当不令人满意。