Rumah > pangkalan data > tutorial mysql > Bagaimana untuk Melaksanakan Pertanyaan Sertai dalam Node.js dengan Sequelize?

Bagaimana untuk Melaksanakan Pertanyaan Sertai dalam Node.js dengan Sequelize?

DDD
Lepaskan: 2024-11-18 06:17:02
asal
372 orang telah melayarinya

How to Perform Join Queries in Node.js with Sequelize?

Cara Melaksanakan Pertanyaan Sertai dalam Node.js Menggunakan Sequelize

Pertanyaan sertai ialah operasi biasa dalam pengurusan pangkalan data. Dalam artikel ini, kami akan meneroka cara melakukan pertanyaan penyertaan menggunakan Sequelize, ORM untuk Node.js.

Pernyataan Masalah Asal

Dalam senario pertanyaan penyertaan biasa, anda mungkin mempunyai dua model : pengguna dan siaran. Matlamatnya adalah untuk mendapatkan semula siaran bersama-sama dengan maklumat pengguna yang berkaitan. Pertanyaan SQL mentah untuk tugas ini boleh jadi:

SELECT * FROM posts, users WHERE posts.user_id = users.id
Salin selepas log masuk

Cabarannya terletak pada menterjemah pertanyaan ini ke dalam gaya ORM Sequelize.

Sequelize Solution

Untuk melakukan gabungan dalaman dalam Sequelize, anda boleh menggunakan kaedah sertakan pada model dan menentukan model yang berkaitan. Contohnya, untuk menyertai siaran dengan pengguna dengan gabungan dalaman:

Posts.findAll({
  include: [{
    model: User,
    required: true  // ensures only posts with users are returned
  }]
}).then(posts => {
  // access posts and related user information
});
Salin selepas log masuk

Variasi

  • Kiri Luar Sertai: Untuk melakukan gabungan luar kiri, tinggalkan pilihan yang diperlukan atau tetapkannya kepada palsu. Ini akan mengembalikan semua siaran, walaupun tanpa pengguna.
  • Menapis Sertai: Untuk menapis hasil gabungan berdasarkan model yang berkaitan, gunakan pilihan tempat dalam blok sertakan. Sebagai contoh, untuk mengambil siaran oleh pengguna yang lahir pada tahun 1984:
Posts.findAll({
  include: [{
    model: User,
    where: { year_birth: 1984 }
  }]
}).then(posts => {
  // ...
});
Salin selepas log masuk
  • Gabungan Kompleks: Anda juga boleh melakukan gabungan yang lebih kompleks menggunakan pelbagai pilihan termasuk dan tempat. Contohnya, untuk mengambil siaran dengan nama "Sunshine" yang dimiliki oleh pengguna yang dilahirkan pada tahun yang sama dengan atribut post_year post:
Posts.findAll({
  where: { name: "Sunshine" },
  include: [{
    model: User,
    where: ["year_birth = post_year"]
  }]
}).then(posts => {
  // ...
});
Salin selepas log masuk

Kesimpulan

Dengan memanfaatkan ORM Sequelize keupayaan, anda boleh melakukan pertanyaan penyertaan dengan cekap dalam Node.js, memudahkan operasi pangkalan data anda dan pengambilan data proses.

Atas ialah kandungan terperinci Bagaimana untuk Melaksanakan Pertanyaan Sertai dalam Node.js dengan Sequelize?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan