10

我一直在尝试为我的项目写一些种子,但我遇到了一些障碍。

我和我的桌子有many-to-many关系。因此,当我为数据库播种时,我需要在我的联接表中添加一条具有正确 ID 的记录。为了做到这一点,我需要找到用户和角色并获取,这就是问题所在。我在sequelize 网站上找不到任何好的文档。我正在使用sequelize-cli进行播种和迁移。我得到一个参数 a ,但我找不到任何例子或提到这件事实际上可以做什么。只是一些简单的例子让我完成了迁移(不知何故)以及我在谷歌上能找到的东西。usersrolesemailnameidsqueryInterface

我已经通过使用我会说的“肮脏技巧”解决了这个问题......

// user_seeds.js
up: function (queryInterface, Sequelize) {
  return queryInterface.bulkInsert(table, [{
    id: 1,
    name: 'John doe',
    email: 'john@doe.com',
    created_at,
    updated_at
}], {});

// roles_seeds.js
up: function (queryInterface, Sequelize) {
  return queryInterface.bulkInsert(table, [{
    id: 1,
    name: 'admin',
    created_at,
    updated_at
  }, {
    id: 2,
    name: 'user',
    created_at,
    updated_at
}]);

//user_roles_seeds.js
up: function (queryInterface, Sequelize) {
    return queryInterface.bulkInsert(table, [{
    employee_id: 1,
    role_id: 1
  }]);
},

不喜欢这个解决方案,因为如果我想再次运行种子并忘记它是如何工作的,将来可能会很麻烦。我应该有一种方法可以使用它来查询数据库queryInterface。我想知道你们中是否有人遇到过这个问题并解决了它,如果有,请分享。

4

3 回答 3

17

是的,您可以使用 queryInterface 来查询数据库。

  async up(queryInterface, Sequelize) {
    const user = await queryInterface.rawSelect('User', {
      where: {
        name: 'John doe',
      },
    }, ['id']);

    if(!user) {
       // do bulkInsert stuff.
    }
  },
于 2017-07-06T03:14:13.170 回答
4

这可能不是解决此问题的最佳做法,但我找不到更好的方法,这足以让我满意。

基本上我所做的是需要所需表的实际模型并使用普通的 Sequelize API 来查找记录。

所以基本上,只需一拳

const { User } = require('./models');

up: function (queryInterface, Sequelize) {
  return User.findOrCreate({
    where: { email: 'john@doe.com' },
    defaults: {
      name: 'John Doe'
    }
  });

等等等等。希望这对某人有所帮助,如果有人有更好的方法,请分享。

于 2016-12-18T18:41:04.113 回答
4

我无法添加评论,尽管这是对此处接受的答案的编辑。

添加plain: false到查询选项以返回所有匹配的条目。Sequelize 似乎没有rawSelect. 但是看看 repo,它基本上是从提供的参数构造一个原始查询。欲了解更多信息https://sequelize.org/master/manual/raw-queries.html

所以它应该是这样的:

const users = await queryInterface.rawSelect(
      'Users',
        {
          where: {
            age: null,
          },
          plain: false,
        },
        ['id'],
      );
于 2021-06-28T09:23:45.200 回答