我有一個經典的ASP頁面,用戶可以搜索屬性和結果頁面,然後通過電子郵件向具有匹配屬性的房產代理髮送電子郵件,讓他們知道有租戶對其屬性感興趣。關鍵字'SELECT'附近的語法不正確
某些代理可能擁有超過1個房產,在這種情況下,代理只需要收到1封電子郵件,而不是每個房產的電子郵件。
我在Management Studio中測試了以下查詢,並返回正確的結果;
SELECT DISTINCT CustomerEmail
FROM (SELECT ContentID
FROM (SELECT ContentID
FROM VWTenantPropertiesResults
WHERE (ContentStreet = '')
UNION ALL
SELECT ContentID
FROM VWTenantPropertiesResults AS VWTenantPropertiesResults_2
WHERE (ContentTown = 'Hull')
UNION ALL
SELECT ContentID
FROM VWTenantPropertiesResults AS VWTenantPropertiesResults_1
WHERE (ContentPostCode = 'HU7')) AS qi
GROUP BY ContentID
HAVING (COUNT(*) >= 2)) AS q INNER JOIN
VWTenantPropertiesResults AS r ON r.ContentID = q.ContentID
WHERE (r.ContentBedRooms BETWEEN 1 AND 4) AND (r.ContentPrice BETWEEN 50 AND 500)
然而,當我在頁面中運行下面的代碼返回關鍵字「SELECT」附近的錯誤語法錯誤;
rsemailagents.Source = "SELECT DISTINCT CustomerEmail"
rsemailagents.Source = rsemailagents.Source& "FROM ("
rsemailagents.Source = rsemailagents.Source& " SELECT ContentID"
rsemailagents.Source = rsemailagents.Source& " FROM ("
rsemailagents.Source = rsemailagents.Source& " SELECT ContentID"
rsemailagents.Source = rsemailagents.Source& " FROM VWTenantPropertiesResults"
rsemailagents.Source = rsemailagents.Source& " WHERE ContentStreet = '" & Replace(rspropertyresults__varReqStreet, "'", "''") & "'"
rsemailagents.Source = rsemailagents.Source& " UNION ALL"
rsemailagents.Source = rsemailagents.Source& " SELECT ContentID"
rsemailagents.Source = rsemailagents.Source& " FROM VWTenantPropertiesResults"
rsemailagents.Source = rsemailagents.Source& " WHERE ContentTown = '" & Replace(rspropertyresults__varReqTown, "'", "''") & "'"
rsemailagents.Source = rsemailagents.Source& " UNION ALL"
rsemailagents.Source = rsemailagents.Source& " SELECT ContentID"
rsemailagents.Source = rsemailagents.Source& " FROM VWTenantPropertiesResults"
rsemailagents.Source = rsemailagents.Source& " WHERE ContentTrimmedPostCode LIKE '" & Replace(varPostcode, "'", "''") & "%'"
rsemailagents.Source = rsemailagents.Source& " ) qi"
rsemailagents.Source = rsemailagents.Source& " GROUP BY"
rsemailagents.Source = rsemailagents.Source& " ContentID"
rsemailagents.Source = rsemailagents.Source& " HAVING COUNT(*) >= 2"
rsemailagents.Source = rsemailagents.Source& " ) q "
rsemailagents.Source = rsemailagents.Source& "JOIN VWTenantPropertiesResults r "
rsemailagents.Source = rsemailagents.Source& "ON r.ContentID = q.ContentID "
rsemailagents.Source = rsemailagents.Source& "WHERE ContentBedrooms BETWEEN " & Replace(rspropertyresults__varBedroomsNoMin, "'", "''") & " "
rsemailagents.Source = rsemailagents.Source& "AND " & Replace(rspropertyresults__varBedroomsNoMax, "'", "''") & " "
rsemailagents.Source = rsemailagents.Source& "AND ContentPrice BETWEEN " & Replace(rspropertyresults__varPriceMin, "'", "''") & " "
rsemailagents.Source = rsemailagents.Source& "AND " & Replace(rspropertyresults__varPriceMax, "'", "''") & " " & varSQL & " "
我想知道是否有人有任何想法,爲什麼DISTINCT不會在代碼中工作?
謝謝。
嘗試打印rsemailagents.Source並與您在Management Studio中測試的查詢進行比較 – 2009-09-23 14:24:12
您還應該能夠看到發送到服務器的SQL以使用SQL Profiler執行。獲取文本數據並嘗試在SSMS中運行 – 2009-09-23 14:28:23