Rumah > pangkalan data > tutorial mysql > Bagaimana untuk Menyertai Subqueries Menggunakan Doktrin 2 DBAL?

Bagaimana untuk Menyertai Subqueries Menggunakan Doktrin 2 DBAL?

DDD
Lepaskan: 2024-10-24 00:15:02
asal
681 orang telah melayarinya

How to Join Subqueries Using Doctrine 2 DBAL?

Sertai Subqueries dengan Doctrine 2 DBAL

Dalam aplikasi Zend Framework 2, Zend_DB sedang digantikan dengan Doctrine 2.5 DBAL. Pertanyaan Zend_DB berikut menunjukkan perkara ini:

$subSelect = $db->select()
    ->from('user_survey_status_entries', array('userSurveyID', 'timestamp' => 'MIN(timestamp)'))
    ->where('status = ?', UserSurveyStatus::ACCESSED)
    ->group('userSurveyID');


$select = $db->select()
    // $selectColNames contains columns both from the main query and 
    // the subquery (e.g. firstAccess.timestamp AS dateFirstAccess).
    ->from(array('us' => 'user_surveys'), $selectColNames)
    ->joinLeft(array('firstAccess' => $subSelect), 'us.userSurveyID = firstAccess.userSurveyID', array())
    ->where('us.surveyID = ?', $surveyID);
Salin selepas log masuk

Walau bagaimanapun, pengguna ingin menyertai subkueri menggunakan pembina pertanyaan Doktrin 2.5 dan memilih lajur daripada subkueri dalam pertanyaan utama. Malangnya, Doktrin tidak menyokong penyertaan subkueri.

Mujurlah, pengguna boleh menggunakan pembina pertanyaan SQL Doktrin DBAL untuk menulis pertanyaan ini:

$subSelect = $connection->createQueryBuilder()
    ->select(array('userSurveyID', 'MIN(timestamp) timestamp'))
    ->from('user_survey_status_entries')
    // Instead of setting the parameter in the main query below, it could be quoted here:
    // ->where('status = ' . $connection->quote(UserSurveyStatus::ACCESSED))
    ->where('status = :status')
    ->groupBy('userSurveyID');

$select = $connection->createQueryBuilder()
    ->select($selectColNames)
    ->from('user_surveys', 'us')
    // Get raw subquery SQL and wrap in brackets.
    ->leftJoin('us', sprintf('(%s)', $subSelect->getSQL()), 'firstAccess', 'us.userSurveyID = firstAccess.userSurveyID')
    // Parameter used in subquery must be set in main query.
    ->setParameter('status', UserSurveyStatus::ACCESSED)
    ->where('us.surveyID = :surveyID')->setParameter('surveyID', $surveyID);
Salin selepas log masuk

Atas ialah kandungan terperinci Bagaimana untuk Menyertai Subqueries Menggunakan Doktrin 2 DBAL?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php
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