Delphi-PRAXiS

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Programmieren allgemein (https://www.delphipraxis.net/40-programmieren-allgemein/)
-   -   [VB.Net] Windows Indexdienst mit limitierter Resultat-Anzahl abfragen (https://www.delphipraxis.net/166925-%5Bvbulletin-net%5D-windows-indexdienst-mit-limitierter-resultat-anzahl-abfragen.html)

s.h.a.r.k 6. Mär 2012 09:23

[VB.Net] Windows Indexdienst mit limitierter Resultat-Anzahl abfragen
 
Guten Morgen zusammen,

sitze gerade vor dem Probleme eine Suche für ein Intranet neu zu schreiben. Diese basiert auf dem Windows Indexdienst, der auf einem Windows Server 2008 läuft. Habe dafür dann eine ASP.NET WVC 2 Anwendung erstellt und soweit alles gecodet. So frage ich bisher den Index ab, was auch wunderbar funktioniert:
Code:
Public Function GetQueryString() As String
    Dim QueryString As String = "SELECT Rank, DocTitle, Filename, Path, VPath, Url, Size, Write, Characterization" _
                              & " FROM SCOPE()" _
                              & " " & GetWhereClause() _
                              & " " & GetOrderClause() _
                              '& " " & GetLimitClause()
    Return QueryString
End Function


' und irgendwo dann...
_Connection = New OleDb.OleDbConnection()
_Connection.ConnectionString = "Provider=MSIDXS.1;Integrated Security .='';Data Source='System'"
_Connection.Open()

' Hier nun die Abfrage
Dim Command As IDbCommand = _Connection.CreateCommand()
Try
    Command.CommandText = _QueryStringBuilder.GetQueryString()
    Dim Reader As IDataReader = Command.ExecuteReader()
    GenerateSearchResults(Reader)
Finally
    Command.Dispose()
End Try
Sind allerdings sehr viele Ergebnisse im Pool ists natürlich sehr blöd, alle Ergebnisse anzuzeigen. Daher wollte ich ein LIMIT einbauen, welches aber nicht funktioniert, daher ist die Methode GetLimitClause auskommentiert. Ebenso funktioniert auch kein SELECT TOP 10...

Fehlermeldung wenn ich LIMIT verwende:
Code:
Falsche Syntax in der Nähe von "LIMIT". Es wurde "end-of-file, ',', ';'" erwartet. SQLSTATE=42000
Fehlermeldung wenn ich SELECT TOP 10 verwende:
Code:
Falsche Syntax in der Nähe von "10". Es wurde "',', '.', FROM" erwartet. SQLSTATE=42000
So, nun habe ich mir auch online einiges durchgelesen, aber leider null dazu gefunden. Vielleicht kann mir ja einer von euch weiterhelfen, wie ich denn die Query beschränken kann!?

Morphie 6. Mär 2012 10:21

AW: [VB.Net] Windows Indexdienst mit limitierter Resultat-Anzahl abfragen
 
MSIDXS bietet keine limitierungen an.

s.h.a.r.k 6. Mär 2012 13:14

AW: [VB.Net] Windows Indexdienst mit limitierter Resultat-Anzahl abfragen
 
Aua... Bist du dir da sicher? Sowas kann doch nicht sein, oder? Ich will doch nicht jedes mal das komplette Resultset haben. Ist doch auch übelst Aufwand für den Server.

-- Edit: Wie ich gerade gesehen habe ist das alles sehr beschränkt... Schade eigentlich. Gibts eigentlich bessere Schnittstellen? Habe dies bzgl. nichts mehr gefunden.

Elvis 6. Mär 2012 13:34

AW: [VB.Net] Windows Indexdienst mit limitierter Resultat-Anzahl abfragen
 
Zitat:

Zitat von s.h.a.r.k (Beitrag 1154773)
Aua... Bist du dir da sicher? Sowas kann doch nicht sein, oder? Ich will doch nicht jedes mal das komplette Resultset haben. Ist doch auch übelst Aufwand für den Server.

Was würde "Limit" denn anderes machen als nach X rows aufzuhören?
Da du da eine Sortierung drin hast, muss er sich sowieso das gesamte Set anschauen.
Du hast doch da einen DataReader, breche also selbst nach X Rows ab.
Einfach mal kurz nachdenken, was du da mit deinem SQL für eine Anforderung n den Index Provider stellst. Der kann doch nicht zaubern.
Und wenn er nicht zaubern kann, warum sollte ein Limit/Top signifikant schneller sein, als den Reader frühzeitig abzubrechen?


Alle Zeitangaben in WEZ +1. Es ist jetzt 21:37 Uhr.

Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz