首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用pg-promise的复合类型

使用pg-promise的复合类型
EN

Stack Overflow用户
提问于 2017-05-01 15:50:52
回答 1查看 568关注 0票数 2

下面是一个示例代码:

代码语言:javascript
复制
battle.heroes = [{ id: hero.id, name: hero.name }]; //This is my array I want to insert
await db.one('INSERT INTO battles(mode, params, heroes) VALUES(${mode}, ${params}, ${heroes}) RETURNING id', {
    mode: battle.mode,
    params: battle.params,
    heroes: battle.heroes,
});

信息类型‘PostgreSQL _info’:

代码语言:javascript
复制
id int4
name varchar
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2017-05-01 20:29:21

通过Custom Type Formatting呈现每个数组元素,方法是使用rawTypetoPostgres扩展现有对象,或者使用您自己的自定义类型,如下所示:

代码语言:javascript
复制
const hero = (id, name) => ({
   rawType: true,
   toPostgres: () => pgp.as.format('($1, $2)::hero_info', [id, name])
});

使用示例:

代码语言:javascript
复制
const heroes = [hero(1, 'first'), hero(2, 'second')];

await db.one('INSERT INTO battles(mode, params, heroes) VALUES(${mode}, ${params}, ${heroes}) RETURNING id', {
    mode: battle.mode,
    params: battle.params,
    heroes
});

对于上面的代码,您的heros数组将正确地格式化为:

array[(1, 'first')::hero_info, (2, 'second')::hero_info]

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

https://stackoverflow.com/questions/43715976

复制
相关文章

相似问题

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