pg-обещание: обновление строки с текстовым столбцом массива с помощью pgp.helpers.update - PullRequest
1 голос
/ 28 февраля 2020

Я пытаюсь обновить столбец текстового массива:

var data = [];

for (const tag of tags) {
    var tmp = {'rids': [rid], 'id': tag.id, 'uid' : uid};
    data.push(tmp);
}

const condition = pgp.as.format(' WHERE CAST(v.uid AS INTEGER) = t.uid and v.id = t.id');
const insertQuery = pgp.helpers.update(data, ['?id', '?uid', 'rids'], 'table_tags') + condition + ' ' + 'RETURNING t.tag';


return db.any(insertQuery);

Это работает, но заменяет значение столбца.

Как сохранить текущее значение столбца и добавить новые?

Например: {somevalue, someothervalue, newinsertedvalue} Вместо: {newinsertedvalue}

Этот запрос я использовал в php drupal проекте:

db_query("UPDATE table_tags set rids = rids || (:rid) WHERE uid = :uid and id = :id", array(':rid' => '{'.$rid.'}', ':uid' => $uid, ':id' => $tag_id));

1 Ответ

1 голос
/ 02 марта 2020

Ваша логика конкатенации значений c является особым случаем, не поддерживается по умолчанию update. Вам нужно будет написать запрос статически, с использованием динамических c значений - значений, сгенерированных с помощью функции helpers.values ​​.


const values = helpers.values(data, ['id', 'uid', 'rids']);

const query = `UPDATE table_tags AS t SET rids = t.rids || v.rids FROM 
    (VALUES${values}) as v(id, uid, rids)
    WHERE CAST(v.uid AS INTEGER) = t.uid AND v.id = t.id RETURNING t.tag`.
...