2015-12-15 166 views
0

我有以下DQL查詢未知列在where子句

SELECT 
    ps.id, 
    MAX(ps.dueDate) as due_date, 
    u.firstName as first_name, 
    u.lastName as last_name, 
    u.email, 
    IDENTITY(ps.loanApplication) as loan_application_id, 
    DATE_DIFF(MAX(ps.dueDate), CURRENT_DATE()) as diff 
FROM 
    Loan\Entity\PaymentSchedule ps 
LEFT JOIN 
    ps.paymentType pt 
LEFT JOIN 
    ps.loanApplication la 
LEFT JOIN 
    la.status s 
LEFT JOIN 
    la.user u 
WHERE 
    pt.slug != :paymentSlug AND s.keyIdentifier = :status AND diff = 14 
GROUP BY 
    ps.loanApplication 

它轉換爲以下SQL查詢

SELECT 
    p0_.id AS id_0, 
    MAX(p0_.due_date) AS sclr_1, 
    u1_.first_name AS first_name_2, 
    u1_.last_name AS last_name_3, 
    u1_.email AS email_4, 
    p0_.loan_application_id AS sclr_5, 
    DATEDIFF(MAX(p0_.due_date), CURRENT_DATE) AS sclr_6 
FROM 
    payment_schedule p0_ 
LEFT JOIN 
    payment_type p2_ ON p0_.payment_type_id = p2_.id 
LEFT JOIN 
    loan_application l3_ ON p0_.loan_application_id = l3_.id 
LEFT JOIN 
    loan_application_status l4_ ON l3_.loan_application_status_id = l4_.id 
LEFT JOIN 
    user u1_ ON l3_.user_id = u1_.id 
WHERE 
    p2_.slug <> ? AND l4_.key_identifier = ? AND sclr_6 = 14 
GROUP BY 
    p0_.loan_application_id 

這給了我下面的錯誤

====================================================================== 
PDOException 
SQLSTATE[42S22]: Column not found: 1054 Unknown column 'sclr_6' in 'where clause' 
---------------------------------------------------------------------- 

當我更換WHERE條件

WHERE pt.slug != :paymentSlug AND s.keyIdentifier = :status AND diff = 14 

隨着

WHERE pt.slug != :paymentSlug AND s.keyIdentifier = :status 

它完美,並顯示了我正確的記錄,我也嘗試以下WHERE條件

WHERE pt.slug != :paymentSlug AND s.keyIdentifier = :status AND DATE_DIFF(MAX(ps.dueDate), CURRENT_DATE()) = :days_diff 

WHERE pt.slug != :paymentSlug AND s.keyIdentifier = :status HAVING (DATE_DIFF(MAX(ps.dueDate), CURRENT_DATE())) = :days_diff 

WHERE以上不工作,以及,我失去了什麼嗎?

謝謝。

+0

將DATE_DIFF()向下移動到where子句。 – Cerad

回答

1

如果你想在你的WHERE子句中使用別名,你需要一個sub-select

select * 
from 
(SELECT 
    p0_.id AS id_0, 
    MAX(p0_.due_date) AS sclr_1, 
    u1_.first_name AS first_name_2, 
    u1_.last_name AS last_name_3, 
    u1_.email AS email_4, 
    p0_.loan_application_id AS sclr_5, 
    DATEDIFF(MAX(p0_.due_date), CURRENT_DATE) AS sclr_6 
FROM 
    payment_schedule p0_ 
LEFT JOIN 
    payment_type p2_ ON p0_.payment_type_id = p2_.id 
LEFT JOIN 
    loan_application l3_ ON p0_.loan_application_id = l3_.id 
LEFT JOIN 
    loan_application_status l4_ ON l3_.loan_application_status_id = l4_.id 
LEFT JOIN 
    user u1_ ON l3_.user_id = u1_.id 
) A 
WHERE 
    slug <> ? AND key_identifier = ? AND sclr_6 = 14 

這是怎麼查詢邏輯處理

FROM clause 
WHERE clause 
SELECT clause 
GROUP BY clause 
HAVING clause 
ORDER BY clause 

由於WhereSelect之前,你不能在Where子句中使用alias name

+0

按照你的建議嘗試,它不起作用。 –

+0

@IbrahimAzharArmar - 已更新檢查 –

0

不能使用別名(對最終結果的字段)在條款WHERE;但是,至少在MySQL中,您可以使用HAVING子句,而不需要GROUP BY

+0

它不起作用... –

0

您正在使用的表達式是聚合的結果。替換爲having子句,使查詢看起來像;

SELECT . . . 
WHERE p2_.slug <> ? AND l4_.key_identifier = ? 
GROUP BY p0_.loan_application_id 
HAVING sclr_6 = 14 

請注意,date_diff()不是MySQL中的函數。你打算datediff()

相關問題