AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi Wie finde ich den vorherigen und nachfolgenden Record
Thema durchsuchen
Ansicht
Themen-Optionen

Wie finde ich den vorherigen und nachfolgenden Record

Ein Thema von Josef_D · begonnen am 14. Aug 2013 · letzter Beitrag vom 14. Aug 2013
Antwort Antwort
Josef_D

Registriert seit: 22. Aug 2006
Ort: Aachen
7 Beiträge
 
Delphi XE3 Professional
 
#1

Wie finde ich den vorherigen und nachfolgenden Record

  Alt 14. Aug 2013, 15:56
Datenbank: MS SQL • Version: SQL Server 2005 • Zugriff über: ADOConnection
Hallo Datenbankspezialisten,

ich suche Daten in einer MS SQL Datenbank in einer Tabelle mit momentan 20 exemplarischen Records. Ich finde über ein TADOQuery den gewünschten Record. Ich muß aber vom gefundenen Record aus den vorherigen Record in der Tabelle auch einlesen. Wie finde ich diesen ?
Wenn ich die RecNo des Queries auslese bekomme ich inmmer eine 1, tatsächlich ist jedoch die gefundene Zeile in der Originaltabelle die 14. Zeile und ich muß die 13. ebenfalls auslesen.

Wird jemand aus meiner Frage schlau und weiß Rat ?

Danke
Im Moment programmiere ich noch mit Delphi 5, XE3 ist aber schon bestellt ...
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

Registriert seit: 9. Dez 2005
Ort: Heilbronn
39.851 Beiträge
 
Delphi 11 Alexandria
 
#2

AW: Wie finde ich den vorherigen und nachfolgenden Record

  Alt 14. Aug 2013, 15:59
In deiner Abfrage scheint es aber nur einen Datensatz zu geben, deshalb hat der die Nr. 1.

Wie sieht Deine Abfrage aus?
Markus Kinzler
  Mit Zitat antworten Zitat
Benutzerbild von Olli73
Olli73
Online

Registriert seit: 25. Apr 2008
Ort: Neunkirchen
666 Beiträge
 
#3

AW: Wie finde ich den vorherigen und nachfolgenden Record

  Alt 14. Aug 2013, 16:11
Wenn ich die RecNo des Queries auslese bekomme ich inmmer eine 1, tatsächlich ist jedoch die gefundene Zeile in der Originaltabelle die 14. Zeile und ich muß die 13. ebenfalls auslesen.
Verabschiede dich einfach von der Vorstellung, dass jeder Datensatz in einer SQL-Datenbank eine feste (RecNo-)Nummer bzw. Position hat. Wenn du die Datensätze nummerieren willst, dann brauchst du ein Datenbankfeld das eine solche enthält. Dann kannst du eine SQL-Abfrage machen:

Code:
select * from MeineTabelle where MeinNummernFeld = 13
oder auch dafür sorgen, dass alle Daten in der gewünschten Reihenfolge erscheinen:

Code:
select * from MeineTabelle order by MeinNummernFeld
Dann kannst du dich auch mit Prior/Next in der Datenmenge bewegen.
  Mit Zitat antworten Zitat
Josef_D

Registriert seit: 22. Aug 2006
Ort: Aachen
7 Beiträge
 
Delphi XE3 Professional
 
#4

AW: Wie finde ich den vorherigen und nachfolgenden Record

  Alt 14. Aug 2013, 16:14
Richtig, die Abfrage ergibt nur einen einzigen Datensatz. Aber ich benötige auch die Daten des vorherigen Records, dieser beinhaltet aber nicht den gesuchten Suchbegriff.

Die Abfrage lautet in etwa

qstring := 'SELECT [Time_ms],[MsgProc]'+
',[StateAfter]' +
',[MsgClass]' +
',[MsgNumber]' +
',[Var1]' +
',[Var2]' +
',[Var3]' +
',[Var4]' +
',[Var5]' +
',[Var6]' +
',[Var7]' +
',[Var8]' +
',[TimeString]' +
',[MsgText]' +
',[PLC]';
s := ' FROM [' + NameArchiv + inttostr(k) + '] ';
sub1 := 'Where var1 like ''%' + Edit3.Text + '%'''
qstring := qstring + sub1;

ADOQuery1.SQL.SetText(PWideChar(qstring));
ADOQuery1.Active := TRUE;
Im Moment programmiere ich noch mit Delphi 5, XE3 ist aber schon bestellt ...
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

Registriert seit: 17. Sep 2006
Ort: Barchfeld
27.542 Beiträge
 
Delphi 11 Alexandria
 
#5

AW: Wie finde ich den vorherigen und nachfolgenden Record

  Alt 14. Aug 2013, 16:22
Was ist denn das Kriterium für den "vorherigen" Record?
Detlef
"Ich habe Angst vor dem Tag, an dem die Technologie unsere menschlichen Interaktionen übertrumpft. Die Welt wird eine Generation von Idioten bekommen." (Albert Einstein)
Dieser Tag ist längst gekommen
  Mit Zitat antworten Zitat
Josef_D

Registriert seit: 22. Aug 2006
Ort: Aachen
7 Beiträge
 
Delphi XE3 Professional
 
#6

AW: Wie finde ich den vorherigen und nachfolgenden Record

  Alt 14. Aug 2013, 16:25
Ein Kriterium für den vorherigen Record ist der gleiche TimeString bzw gleiches Time_ms wie bei der gefundenen Zeile. Mmh... ich könnte natürlich eine zweite Suche danach starten, aber das ist mir irgendwie nicht elegant genug , aber wenns nicht anders geht....
Im Moment programmiere ich noch mit Delphi 5, XE3 ist aber schon bestellt ...
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

Registriert seit: 17. Sep 2006
Ort: Barchfeld
27.542 Beiträge
 
Delphi 11 Alexandria
 
#7

AW: Wie finde ich den vorherigen und nachfolgenden Record

  Alt 14. Aug 2013, 16:31
So richtig habe ich die Struktur zwar nicht verstanden, aber vielleicht hilft eine Subquery weiter in der Art
SQL-Code:
SELECT
  <FeldListe>
FROM
  <Tabelle>
WHERE
  TimeString =
  (
    SELECT
      TimeString
    FROM
      <Tabelle>
    WHERE
      var1 LIKE 'Wasweißich'
  )
Detlef
"Ich habe Angst vor dem Tag, an dem die Technologie unsere menschlichen Interaktionen übertrumpft. Die Welt wird eine Generation von Idioten bekommen." (Albert Einstein)
Dieser Tag ist längst gekommen
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

Registriert seit: 9. Dez 2005
Ort: Heilbronn
39.851 Beiträge
 
Delphi 11 Alexandria
 
#8

AW: Wie finde ich den vorherigen und nachfolgenden Record

  Alt 14. Aug 2013, 16:34
Hat die Tabelle einen Primärschlüssel?
Markus Kinzler
  Mit Zitat antworten Zitat
Josef_D

Registriert seit: 22. Aug 2006
Ort: Aachen
7 Beiträge
 
Delphi XE3 Professional
 
#9

AW: Wie finde ich den vorherigen und nachfolgenden Record

  Alt 14. Aug 2013, 16:44
Die Tabelle wird von einem Siemens-Programm angelegt und hat keinen Primärschlüssel. Ich versuche gerade die Sache mit dem SubQuery, mal sehen ....
Im Moment programmiere ich noch mit Delphi 5, XE3 ist aber schon bestellt ...
  Mit Zitat antworten Zitat
Josef_D

Registriert seit: 22. Aug 2006
Ort: Aachen
7 Beiträge
 
Delphi XE3 Professional
 
#10

AW: Wie finde ich den vorherigen und nachfolgenden Record

  Alt 14. Aug 2013, 16:48
Das mit dem SubQuery hilft schon mal weiter, gute Idee, vielen Dank für die Hilfe.
Im Moment programmiere ich noch mit Delphi 5, XE3 ist aber schon bestellt ...
  Mit Zitat antworten Zitat
Antwort Antwort


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 17:18 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