1. ホーム
  2. mysql

[解決済み] Node.jsでSequelizeを使用して結合クエリを作成する方法

2022-02-14 12:45:34

質問

私はsequelize ORMを使用しています。すべてが素晴らしく、きれいですが、それを join クエリを実行します。 私は2つのモデルを持っています:ユーザーと投稿。

var User = db.seq.define('User',{
    username: { type: db.Sequelize.STRING},
    email: { type: db.Sequelize.STRING},
    password: { type: db.Sequelize.STRING},
    sex : { type: db.Sequelize.INTEGER},
    day_birth: { type: db.Sequelize.INTEGER},
    month_birth: { type: db.Sequelize.INTEGER},
    year_birth: { type: db.Sequelize.INTEGER}

});

User.sync().success(function(){
    console.log("table created")
}).error(function(error){
    console.log(err);
})


var Post = db.seq.define("Post",{
    body: { type: db.Sequelize.TEXT },
    user_id: { type: db.Sequelize.INTEGER},
    likes: { type: db.Sequelize.INTEGER, defaultValue: 0 },

});

Post.sync().success(function(){
    console.log("table created")
}).error(function(error){
    console.log(err);
})

ある投稿に対して、その投稿を行ったユーザーの情報を含むクエリを発行したい。生のクエリでは、私はこれを取得します。

db.seq.query('SELECT * FROM posts, users WHERE posts.user_id = users.id ').success(function(rows){
            res.json(rows);
        });

私の質問は、SQLクエリの代わりにORMスタイルを使用するようにコードを変更するにはどうしたらよいかということです。

どのように解決するのですか?

User.hasMany(Post, {foreignKey: 'user_id'})
Post.belongsTo(User, {foreignKey: 'user_id'})

Post.find({ where: { ...}, include: [User]})

となります。

SELECT
  `posts`.*,
  `users`.`username` AS `users.username`, `users`.`email` AS `users.email`,
  `users`.`password` AS `users.password`, `users`.`sex` AS `users.sex`,
  `users`.`day_birth` AS `users.day_birth`,
  `users`.`month_birth` AS `users.month_birth`,
  `users`.`year_birth` AS `users.year_birth`, `users`.`id` AS `users.id`,
  `users`.`createdAt` AS `users.createdAt`,
  `users`.`updatedAt` AS `users.updatedAt`
FROM `posts`
  LEFT OUTER JOIN `users` AS `users` ON `users`.`id` = `posts`.`user_id`;

上のクエリは、あなたが投稿したものと比べると少し複雑に見えるかもしれませんが、基本的に、usersテーブルのすべてのカラムをエイリアスにして、それらが返されたときに正しいモデルに配置され、postsモデルと混合されないようにしているだけです。

その他、2つのテーブルから選択するのではなく、JOINしていることに気がつくと思いますが、結果は同じはずです。

さらに読む