Пункт ORDER BY недопустим, если TOP или ДЛЯ XML также не указан

Я получаю "Пункт 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)
14
задан MackM 23 February 2018 в 04:00
поделиться

3 ответа

Вы переместили предложение 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
11
ответ дан 1 December 2019 в 12:38
поделиться

Было бы полезно, если бы вы посмотрели на запрос, который генерируется кодом:

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-инъекцией при построении запросов таким образом.

2
ответ дан 1 December 2019 в 12:38
поделиться

Похоже, проблема в том, что вы пытаетесь применить предложение order by к внутреннему оператору select, что запрещено. Вы должны применять предложение order by только к самому внешнему оператору select.

0
ответ дан 1 December 2019 в 12:38
поделиться
Другие вопросы по тегам:

Похожие вопросы: