Я получаю "Пункт ORDER BY, недопустимо в представлениях, подставляемых функциях, получил таблицы, подзапросы и общие выражения таблицы, если TOP или ДЛЯ XML также не указан". ошибка со следующим кодом. У меня первоначально было две таблицы, ADSAREAS & CATEGORIES. Я начал получать эту ошибку, когда я удалил таблицу CATEGORIES.
Select Case SIDX
Case "ID" : SQLCONT1 = " AdsAreasID"
Case "Page" : SQLCONT1 = " AdsAreasName"
Case Else : SQLCONT1 = " AdsAreasID"
End Select
Select Case SORD
Case "asc" : SQLCONT2 = " ASC"
Case "desc" : SQLCONT2 = " DESC"
Case Else : SQLCONT2 = " ASC"
End Select
''# search feature --->
Select Case SEARCHFIELD
Case "ID" : SQLSFIELD = "AND AdsAreasID"
Case "Ads Areas" : SQLSFIELD = "AND AdsAreasName"
Case Else : SQLSFIELD = ""
End Select
Select Case SEARCHOPER
Case "eq" : SQLSOPER = " = " & SEARCHSTRING
Case "ne" : SQLSOPER = " <> " & SEARCHSTRING
Case "lt" : SQLSOPER = " <" & SEARCHSTRING
Case "le" : SQLSOPER = " <= " & SEARCHSTRING
Case "gt" : SQLSOPER = " >" & SEARCHSTRING
Case "ge" : SQLSOPER = " >= " & SEARCHSTRING
Case "bw" : SQLSOPER = " LIKE '" & SEARCHSTRING & "%' "
Case "ew" : SQLSOPER = " LIKE '%" & SEARCHSTRING & "' "
Case "cn" : SQLSOPER = " LIKE '%" & SEARCHSTRING & "%' "
Case Else : SQLSOPER = ""
End Select
''# search feature --->
SQL = "SELECT * FROM ( SELECT A.AdsAreasID, A.AdsAreasName, ROW_NUMBER() OVER (ORDER BY A.AdsAreasID) As Row"
SQL = SQL & " FROM ADSAREAS A"
SQL = SQL & " WHERE Row > ("& RecordsPageSize - RecordsPerPage &") AND Row <= ("& RecordsPageSize &") ORDER BY" & SQLCONT1 & SQLCONT2
Set objXML = objConn.Execute(SQL)
Вы переместили предложение ORDER BY во внутренний запрос, переписав его. Добавьте круглые скобки (и идентификатор) после предложения WHERE, чтобы вместо этого ORDER BY применялся к внешнему SELECT.
SQL = "SELECT * FROM ( SELECT A.AdsAreasID, A.AdsAreasName, ROW_NUMBER() OVER (ORDER BY A.AdsAreasID) As Row"
SQL = SQL & " FROM ADSAREAS A"
SQL = SQL & " WHERE Row > ("& RecordsPageSize - RecordsPerPage &") AND Row <= ("& RecordsPageSize &")) inner ORDER BY" & SQLCONT1 & SQLCONT2
Было бы полезно, если бы вы посмотрели на запрос, который генерируется кодом:
SELECT *
FROM (
SELECT
A.AdsAreasID,
A.AdsAreasName,
ROW_NUMBER() OVER (ORDER BY A.AdsAreasID) As Row
FROM ADSAREAS A
WHERE
Row > ("& RecordsPageSize - RecordsPerPage &")
AND Row <= ("& RecordsPageSize &")
ORDER BY" & SQLCONT1 & SQLCONT2
Обратите внимание, что вам не хватает закрывающего )
, и что если бы один был помещен в конец, ORDER BY
был бы внутри внутреннего запроса, а не внешнего, что недопустимо. Вам лучше полностью удалить внешний запрос. Это бесполезно.
И все это несмотря на проблемы с SQL-инъекцией при построении запросов таким образом.
Похоже, проблема в том, что вы пытаетесь применить предложение order by к внутреннему оператору select, что запрещено. Вы должны применять предложение order by только к самому внешнему оператору select.