首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >我可以在postgres和plpython之间共享复合类型吗?

我可以在postgres和plpython之间共享复合类型吗?
EN

Stack Overflow用户
提问于 2012-09-20 19:11:49
回答 1查看 202关注 0票数 3

我有一个名为tt的复合类型,所有plpgsql和plpythonu过程都要使用它。有没有什么plpy。以一致的方式访问目录或架构以便派生类型或可迭代结构以返回的方法,而不必在plpythonu过程中定义类?

代码语言:javascript
复制
CREATE TYPE tt AS (id integer, name text);
CREATE OR REPLACE FUNCTION python_setof_type() RETURNS SETOF tt AS $$
#-- i want this to be dynamic or to have it's attributes pulled from the tt type
class tt:
    def __init__(self, id, name):
        plpy.info('constructed type')
        self.idx = 0
        self.id = id
        self.name = name

    def __iter__ (self):
        return self

    def next (self):
        if (self.idx == 1):
            raise StopIteration

        self.idx += 1
        return ( self )

return tt(3, 'somename')

#-- was hoping for something like
#-- give me 1 record
#-- return plpy.schema.tt(3, 'somename')

#-- give me 2 records
#-- return plpy.schema.tt([3, 'somename'], [1, 'someornothername'])

#-- give me a no records
#-- return plpy.schema.tt([])
$$ LANGUAGE plpythonu;
EN

回答 1

Stack Overflow用户

发布于 2012-11-01 00:14:59

没有像这样的东西,但这是一个很好的想法。正如您所指出的,您可以通过查询系统目录自己编写它。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/12511431

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档