PostgreSQL
 sql >> Database >  >> RDS >> PostgreSQL

Come inserire nel nome della tabella come alias usando l'helper di inserimento pg-promise?

Puoi utilizzare i tipi flessibili negli helpers namespace per generare il tuo inserto personalizzato:

const pgp = require('pg-promise')(/*initialization options*/);

// data = either one object or an array of objects;
// cs = your ColumnSet object, with table name specified
// alias = the alias name string
function createInsertWithAlias(data, cs, alias) {
    return pgp.as.format('INSERT INTO $1 AS $2~ ($3^) VALUES $4^', [
        cs.table, alias, cs.names, pgp.helpers.values(data, cs)
    ]);
}

e quindi aggiungi semplicemente la clausola di risoluzione dei conflitti, poiché è statica.

API utilizzata nell'esempio: