mysql - 在 Sequelize 中填充没有关联 id 的数据

标签 mysql join sequelize.js associations

我有 4 个表,user、profile、specialty、user_specialities。我正在使用 Sequelize 。我的用户模型是-->

const User = sequelize.define('user', {
user_id: {
        type: Sequelize.INTEGER,
        allowNull: false,
        primaryKey: true,
        autoIncrement: true,
    },
    IsDeleted: {
        type:Sequelize.BOOLEAN,
    },
    status: {
        type:Sequelize.BOOLEAN,
},
});

我的个人资料模型-->

const Profile= sequelize.define('profile', {
    profile_id: {
        type: Sequelize.INTEGER,
        allowNull: false,
        primaryKey: true,
        autoIncrement: true,
    },
    first_name: {
        type:Sequelize.STRING,
    },
    last_name: {
        type:Sequelize.STRING,
    },
},
{
    indexes: [
        {
            unique: true,
            fields: ['user_id']
        }
    ]
});   
Chef_Info.belongsTo(User, {foreignKey: 'user_id'});

专业表-->

    const Profile= sequelize.define('speciality', {
        speciality_id: {
            type: Sequelize.INTEGER,
            allowNull: false,
            primaryKey: true,
            autoIncrement: true,
        },
        title: {
            type:Sequelize.STRING,
        },
}

user_specialities 保存用户和专业之间的多对多关系。我已经使用了这样的 belongsToMany 关联 -

Speciality.belongsToMany(User, {through: 'user_speciality',foreignKey: 'speciality_id', otherKey: 'user_id'});
User.belongsToMany(Speciality, {through: 'user_speciality',foreignKey: 'user_id', otherKey: 'speciality_id'});

现在,我想获取具有 user_id、first_name、last_name 以及专业知识的数据。例如-->

first_name  | last_name     | specialities
Khabib      | Nurmagamedov  | Athlete, Wrestler
Tony        | Ferguson      | Athlete, Striker

我在MySql中尝试过,查询应该是-->

SELECT profiles.first_name,profiles.last_name,GROUP_CONCAT(specialities.title)
FROM (
users
    LEFT JOIN profiles
         ON users.user_id = profiles.user_id 
    LEFT JOIN user_specialities
        ON users.user_id = user_specialities.user_id
    LEFT JOIN specialities
        ON chef_specialities.speciality_id = specialities.speciality_id
)
WHERE(
    AND users.IsDeleted = false
    And users.status = true
)
GROUP BY users.user_id;

但我正在努力将其转换为 Sequelize 。我已经走到这一步了-->

UserSpecialities.findAll({
    attributes:[sequelize.fn('GROUP_CONCAT', sequelize.col('title')), 'speciality_id'],
    include: [
    { 
       model: User,
       attributes: [],
       where:{
           IsRemoved: false,
           status: true,
       },
    },
    { model: Speciality,
         attributes: [],
    },
    ],
    group:['user_id']

它提供了用户方面的专业知识-->

[
    {
        "speciality_id": "Athlete, Wrestler",
    },
    {
        "speciality_id": "Athlete, Striker",
    }
]

但是我无法在此处填充配置文件数据。如果我尝试包含配置文件,它不会显示关联错误,或者我尝试在用户模型中添加 hasMany ,它会再次抛出错误。在这种情况下我该怎么办? 提前致谢。

最佳答案

因为 Profile 与 Users 相关联,但与 UserSpecialties 无关,因此通过两个查询来完成此操作会更有意义。

像上面那样获取您的用户专业,然后获取这些 userId 并获取其关联的个人资料(应该类似于 User.getProfile ,具体取决于您的关联设置方式)。

现在,您已将 UserSpecialties 属性设置为仅返回 professional_id 和 title,如果您将 userId 添加到这些属性中,则可以使用这些 userId 来查询您的个人资料表。 then promise 非常适合这样的事情,例如:

UserSpecialties.findAll({...}).then((userSpecialties) => {
  User.getProfile({where: {userId: userSpecialties.userId}, attributes: {'first_name', 'last_name'})
});

根据您具体尝试对信息执行的操作,您可能需要对其进行一些调整,但一般的想法是添加 userId 作为属性,然后使用 UserSpecialties 中的 userId 查询用户表中的配置文件查询结果应该可以很好地满足您想要的数据。

尽管查看您的模型,将配置文件和用户放在一个表中可能是有意义的,其中用户具有名字、姓氏、用户 ID 和状态。由于 Profile 没有太多其他内容,因此如果您需要 userProfile 的特定内容,您可以在用户模型上使用范围。

关于mysql - 在 Sequelize 中填充没有关联 id 的数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55253236/

相关文章:

java - play scala 中 Magic 的 ColumnNotFound 问题

php - 在两个表之间使用 id 来输出想要的数据

mysql - 无数的WHERE条件mysql

php - 使用 simpleXML 将 xml 数据插入 mysql

mysql - Sequel Pro 中导出/导入时丢失 utf8mb4 字符

PHP mySQL结构输出树

node.js - 检查该值是否是模型 Sequelize 中的电话号码

javascript - Sequelize 获取上次更新或创造值(value)

sequelize.js - Sequelize Eager Loading check query (ex : it has. ..?)

php - 将 require 语句与 if/else if 语句一起使用