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

Bagaimana untuk Menyertai Subqueries Menggunakan Doktrin 2 DBAL?

DDD
DDDasal
2024-10-24 00:15:02717semak imbas

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);

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);

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!

Kenyataan:
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