首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >当需要检查jsonb列中是否存在键时,如何使用Sequelize中的queryInterface.bulkUpdate?

当需要检查jsonb列中是否存在键时,如何使用Sequelize中的queryInterface.bulkUpdate?
EN

Stack Overflow用户
提问于 2021-10-28 21:26:53
回答 1查看 174关注 0票数 1

我想使用Sequelize迁移来更新Postgres数据库中的一个表。

我的SQL查询对JSONB列使用Postgres中的de ?运算符。

我需要运行的SQL查询是:

代码语言:javascript
复制
UPDATE messages SET type = 'products' WHERE type = 'gallery' and content ? '%textMain%'

我在Sequelize中的迁移如下所示:

代码语言:javascript
复制
'use strict';

module.exports = {
  up: async (queryInterface, Sequelize) => {
    await queryInterface.bulkUpdate(
      'messages', 
      { type: 'products' }, 
      // HERE GOES THE WHERE CLAUSE
    )
  },

  down: async (_queryInterface, _Sequelize) => {
  }
};
EN

回答 1

Stack Overflow用户

发布于 2021-10-28 21:26:53

在掉了一些头发后寻找答案。

我这样解决了这个问题:

代码语言:javascript
复制
'use strict';

module.exports = {
  up: async (queryInterface, Sequelize) => {
    await queryInterface.bulkUpdate(
      'messages', 
      { type: 'products' }, 
      Sequelize.literal("type = 'gallery' AND content ? 'textMain'")
    )
  },

  down: async (_queryInterface, _Sequelize) => {
  }
};

希望它能帮助其他有同样问题的人!:+1

我很乐意看到解决这个问题的其他方法。

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

https://stackoverflow.com/questions/69761138

复制
相关文章

相似问题

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