Erweiterung bei Selektionen

Variable Abfragemöglichkeiten der Datenbank durch den Endanwender sind in vielen Applikationen eingebaut. Da hier das Selektionsergebnis von den eingegebenen Daten abhängt, sind der Umfang des Ergebnisses und die Abfragedauer nicht vorhersehbar. Problematisch können hier beispielsweise Wildcard-Eingaben sein, bei denen die Selektion minutenlang läuft und eine riesige Ergebnismenge liefert, die der Endanwender nicht gebrauchen kann.


Seit der Version 5.7.06 kann die Ergebnismenge (und damit auch die Durchführungsdauer) einer Selektion beschränkt werden. Dazu wird die maximale Anzahl von Datensätzen in der Ergebnismenge beim Befehl SelRun() als optionales Argument übergeben. Wird während der Durchführung dieses Limit überschritten, beendet sich die Abfrage und SelRun() liefert als Resultat _rLimitReached.

Limitiertes Ergebnis

Bei einem Limit von 1000 Sätzen wird die Selektion vorzeitig beendet, wenn der 1001ste Datensatz gefunden ist. Bei genau 1000 gefundenen Sätzen ist das Resultat _rOK. Die Ergebnismenge bei _rLimitReached ist gemäß der Selektionsdefinition sortiert und auch genauso verwendbar, wie eine vollständige Ergebnismenge. Jedoch stellt diese limitierte Menge einen zufälligen Ausschnitt aus der potenziellen Gesamtergebnismenge dar. Es sind also nicht die "ersten" x Sätze in Bezug auf irgendeine Sortierung.

Vorauswahlen

Die Durchführung von Vorauswahlen wird durch das Limit nicht beeinflusst, da das Zwischenresultat einer Vorauswahl keine Rückschlüsse auf die zu erwartende Endergebnismenge zulässt. Dies gilt auch für eine Selektion, bei der ausschließlich mit Vorauswahlen gearbeitet wird und deren Resultat unsortiert ist. Da in diesem Fall nur Schlüsselwerte und keine Datensätze gelesen werden, wirkt in diesem Fall das Limit nicht.

Limit = 0

Die Angabe von 0 als Limit ist zulässig, dabei beendet sich die Selektion beim ersten gefundenen Datensatz. Das kann sinnvoll sein, wenn die Applikation ermitteln will, ob es überhaupt einen passenden Datensatz in einer Tabelle gibt. Hierbei müssen gegebenenfalls nicht alle Sätze der Tabelle gelesen werden, beim ersten Treffer ist die Selektion zu Ende.

Das Limit kann bei allen Optionen außer _SelUnion, _SelInter und _SelMinus verwendet werden, somit ist es auch bei der serverseitigen Ausführung (_SelServer) einsetzbar.

Klicken Sie hier, um die Nutzungsbedingungen für unseren Blog zu lesen.

2 Antworten

  1. Das Limit = 0 ist sehr Interessant.
    Tipp:
    In besonderen fällen verwenden wir Selektion mittels RmtCall. Da RmtCall Asyncon läuft, wird die Selektion vom Aufrufer zuvor gesperrt. Ist die RmtCall Selektion beendet, wird diese dort ensperrt (Schleife z.B. mit 0,1 sek. vom Aufrufer Sperre prüfen). Die Serverleistung sollte daher gut sein.

    1. Anwendungsfall
    Die Ergebnismenge aktualisert Datensätze > 20 mal schneller.
    Es sind Daten die fast immer zu 100% im Cache sind.
    2. Anwendungsfall
    Sie soll noch schneller sein, bei Tests waren diese etwa 4-5 mal schneller. Statt 4-5 sek. ca. 1 sek.

Schreiben Sie einen Kommentar

Ihre E-Mail-Adresse wird nicht veröffentlicht. Erforderliche Felder sind mit * markiert

Leave the field below empty!

Wünsche, Fragen oder Feedback sind willkommen:

Nutzungsbedingungen der Kommentarfunktion im Blog

1. Allgemeines

Vectorsoft AG („Anbieter“) stellt für Internetnutzer („Nutzer“) auf der Website
vectorsoft.de einen öffentlichen Blog bereit. Der öffentliche Blog dient dem
Informations- und Gedankenaustausch. Die Nutzer, welche sich mit Beiträgen und
Kommentaren beteiligen, verpflichten sich dazu, die Blog-Nutzungsbedingungen
einzuhalten und tragen die Verantwortung für die Richtigkeit und Angemessenheit
sowie Freiheit von Rechtsverletzungen ihrer Beiträge. Mit Nutzung der
Kommentarfunktion in unserem Blog akzeptieren Sie diese Nutzungsbedingungen.

2. Netiquette

Wir bitten Sie von persönlichen Angriffen und Provokationen aufgrund anderer
Meinungen abzusehen. Bitte argumentieren Sie sachlich und bewegen Sie sich auf
der Basis einer konstruktiven Diskussionskultur. Ihr Kommentar sollte stets im
Zusammenhang mit dem jeweiligen Thema sein, um Ausschweifungen in andere
Themenbereiche zu vermeiden. Das mehrmalige Posten desselben Kommentars
oder mehrerer ähnlicher Kommentare ist nicht erlaubt.

3. Verbot rechtswidriger Inhalte

Mit Absenden Ihres Kommentars bestätigen Sie, dass Sie keine Urheberrechte oder andere Rechte Dritter verletzen. Volksverhetzende, rassistische Äußerungen, Anleitungen zu Straftaten und deren Verherrlichung, Gewaltdarstellungen, pornografische Inhalte und Äußerungen, die Persönlichkeitsrechte verletzen sind untersagt.

4. Keine Werbung

Die Nutzung der Kommentarfunktion ist für kommerzielle oder parteipolitische
Zwecke nicht erlaubt. Werbliche Beiträge aller Art werden von uns umgehend
gelöscht.

5. Angaben zum Namen

Bei der Eingabe Ihres Namens achten Sie auf die zuvor genannten Grundsätze.

6. Quellenangaben

Bitte geben Sie bei der beabsichtigten Veröffentlichung von Zitaten oder Beiträgen
Dritter die jeweiligen Quellen an und erläutern dessen Bezug zum Blogbeitrag.

7. Verstoß gegen die Nutzungsbedingungen

Beiträge, die gegen diese Richtlinie verstoßen werden umgehend gelöscht. Sollten
Sie selbst Verstöße bemerken, so senden Sie uns bitte den Link des betreffenden
Kommentars per E-Mail an . Wir weisen ausdrücklich daraufhin, dass wir einzelne Nutzer bei wiederholten oder schweren Verstößen gegen diese
Nutzungsbedingungen ausschließen werden.

Stand: Sept. 2024

Deine Trial Version - jetzt anfordern!

Teste yeet - unverbindlich und kostenfrei

IHRE EVALUIERUNGSLIZENZ - JETZT ANFORDERN!

TESTEN SIE DIE CONZEPT 16 VOLLVERSION - UNVERBINDLICH und KOSTENFREI

Melden Sie sich bei unserem Newsletter an

Anrede*
     
Zustimmung zur Datenverarbeitung gem. DSGVO*



WordPress Cookie-Hinweis von Real Cookie Banner