コードの例を次に示します。
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タイプ 'hero_info':
id int4
name varchar
既存のオブジェクトをとで拡張するか、以下のような独自のカスタムタイプを使用して、カスタムタイプフォーマットを介して各配列要素を提示します。rawType
toPostgres
const hero = (id, name) => ({
rawType: true,
toPostgres: () => pgp.as.format('($1, $2)::hero_info', [id, name])
});
使用例:
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]
この記事はインターネットから収集されたものであり、転載の際にはソースを示してください。
侵害の場合は、連絡してください[email protected]
コメントを追加