Bizarre problem: Python stored procedure using protocol buffers not working - Mailing list pgsql-general

From Yang Zhang
Subject Bizarre problem: Python stored procedure using protocol buffers not working
Date
Msg-id AANLkTikwcyb42VgUGtCewJJKewOl6luq5NUfdp39K5zi@mail.gmail.com
Whole thread Raw
Responses Re: Bizarre problem: Python stored procedure using protocol buffers not working  (Peter Eisentraut <peter_e@gmx.net>)
List pgsql-general
I have a table containing a protocol buffer (pb) attribute, and a
stored procedure foo that tries to parse it and return the parsed
value as a human-friendly string (not actual application code, just a
minimal test case to demonstrate the problem). But running foo gives
me nothing back.

yang=# \d qapb
     Table "public.qapb"
 Column |  Type   | Modifiers
--------+---------+-----------
 id     | integer |
 pb     | bytea   |

yang=# select * from qapb;
 id |                                   pb
----+------------------------------------------------------------------------
  0 | \012\006hello?\020\000\030\000 \000*\014\012\006hello!\020\000\030\000
(1 row)

yang=# create or replace function foo() returns text as $$
import sys, plpy
if '/home/yang/work/pod/' not in sys.path:
sys.path.append('/home/yang/work/pod/')
from my_pb2 import * # this is a protobuf generated module
rv = plpy.execute('select * from qapb')
q = Q()
q.ParseFromString(str(rv[0]['pb']))
return str(q);
$$ language plpythonu;
CREATE FUNCTION
yang=# select foo();
 foo
-----

(1 row)

From a Python prompt, this works fine. I also verified that parsing
works fine from a Python client that first pulls the blob out and
parses client-side.

>>> from my_pb2 import *
>>> q=Q()
>>> q.ParseFromString('\012\006hello?\020\000\030\000 \000*\014\012\006hello!\020\000\030\000')
>>> print q
a: "hello?"
b: 0
c: 0
d: 0
e {
  a: "hello!"
  b: 0
  c: 0
}

Any hints on how I can get to the bottom of this? Thanks in advance.
--
Yang Zhang
http://yz.mit.edu/

pgsql-general by date:

Previous
From: Tom Lane
Date:
Subject: Re: Query memory usage
Next
From: gaime igner
Date:
Subject: How to Insert Async