AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Zum nächsten Datensatz springen
Thema durchsuchen
Ansicht
Themen-Optionen

Zum nächsten Datensatz springen

Ein Thema von Luckie · begonnen am 8. Jun 2010 · letzter Beitrag vom 9. Jun 2010
Antwort Antwort
Seite 2 von 7     12 34     Letzte »    
idefix2

Registriert seit: 17. Mär 2010
Ort: Wien
1.027 Beiträge
 
RAD-Studio 2009 Pro
 
#11

AW: Zum nächsten Datensatz springen

  Alt 8. Jun 2010, 12:19
Ich nehme an, er braucht dann nicht nur die id, sondern den ganzen nächsten Datensatz. Den will er ja anzeigen.
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

Registriert seit: 17. Sep 2006
Ort: Barchfeld
27.625 Beiträge
 
Delphi 12 Athens
 
#12

AW: Zum nächsten Datensatz springen

  Alt 8. Jun 2010, 12:21
Zitat:
Code:
return $prevID->id;
Nö, nur die ID. Also kauft er für ein Glas Milch gleich eine ganze Kuh
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
Benutzerbild von Luckie
Luckie

Registriert seit: 29. Mai 2002
37.621 Beiträge
 
Delphi 2006 Professional
 
#13

AW: Zum nächsten Datensatz springen

  Alt 8. Jun 2010, 12:28
Ja, ich brauche nur die ID. Aber Optimierung kommt später. Erst mal soll es überhaupt funktionieren.

@Idefix: Ich werde deine Lösung nachher mal ausprobieren.
Michael
Ein Teil meines Codes würde euch verunsichern.
  Mit Zitat antworten Zitat
Benutzerbild von Luckie
Luckie

Registriert seit: 29. Mai 2002
37.621 Beiträge
 
Delphi 2006 Professional
 
#14

AW: Zum nächsten Datensatz springen

  Alt 8. Jun 2010, 18:08
@Idefix: Jetzt geht er aber nur die Datensätze durch, bei denen das Feld gesch_firma nicht leer ist. Aber ich brauche natürlich auch alle anderen, also bei denen gesch_firma oder name oder vorname leer ist.
Michael
Ein Teil meines Codes würde euch verunsichern.
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

Registriert seit: 17. Sep 2006
Ort: Barchfeld
27.625 Beiträge
 
Delphi 12 Athens
 
#15

AW: Zum nächsten Datensatz springen

  Alt 8. Jun 2010, 19:52
Wie sieht es so aus?
SQL-Code:
SELECT
  ID
FROM
  adressen
WHERE
  CONCAT_WS(' ',gesch_firma,name,vorname) >=
    (SELECT
       CONCAT_WS(' ',gesch_firma,name,vorname)
     FROM
       adressen
     WHERE ID = $id)
AND
  ID <> $id
ORDER BY
  gesch_firma,name,vorname
LIMIT 1
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

Geändert von DeddyH ( 8. Jun 2010 um 20:00 Uhr) Grund: Code Formatierung für SQL aktiviert
  Mit Zitat antworten Zitat
idefix2

Registriert seit: 17. Mär 2010
Ort: Wien
1.027 Beiträge
 
RAD-Studio 2009 Pro
 
#16

AW: Zum nächsten Datensatz springen

  Alt 8. Jun 2010, 20:30
Das klingt sehr danach, als wären doch NULLs im Spiel (dann wird übrigens die von DeddyH vorgeschlagene Abfrage das gleiche Ergebnis liefern). Der normale Leerstring wird im Vergleich kleiner als jeder andere String gereiht und ganz normal verglichen - für den Algorithmus macht also ein Leerstring keinen Unterschied. Die Datensätze, bei denen gesch_firma den Leerstring enthalten, müssten als erste angezeigt werden.

Wenn allerdings ein Feld NULL enthält, ergibt jeder Vergleich mit dem Feld ebenfalls NULL, was zur Folge hat, dass die Query keine Datensätze liefert, bei denen auch nur eines der drei Felder NULL ist.

Ich versuche, in meinen Datenbanken NULL wo immer es geht zu vermeiden, weil dieser Wert das ganze Handling (meistens unnötig) kompliziert.

edit: Die Abfrage aus Post 15 würde durch das ">=" eine Endlosschleife produzieren, wenn in der DB zwei Datensätze liegen, bei denen das concat der drei Felder gesch_firma, name und vorname den selben Wert ergibt, z.B. Firma Maier mit Leerstring als Name und Vorname und Person Maier mit Leerstring als gesch_firma und vorname.

edit 2: Ich habe eben geschrieben "was zur Folge hat, dass die Query keine Datensätze liefert, bei denen auch nur eines der drei Felder NULL ist." Das stimmt so aber nicht ganz, weil zwar fast alle Operationen, in die ein NULL-Wert involviert ist, wieder NULL ergeben, es gibt aber glaube ich zwei Ausnahmen: (NULL and false) liefert false, (NULL or true) liefert true.

Geändert von idefix2 ( 8. Jun 2010 um 21:01 Uhr)
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

Registriert seit: 17. Sep 2006
Ort: Barchfeld
27.625 Beiträge
 
Delphi 12 Athens
 
#17

AW: Zum nächsten Datensatz springen

  Alt 8. Jun 2010, 21:22
Ich habe noch nie gehört, dass ein SQL-Statement ein Endlosschleife ergeben soll
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
Benutzerbild von Luckie
Luckie

Registriert seit: 29. Mai 2002
37.621 Beiträge
 
Delphi 2006 Professional
 
#18

AW: Zum nächsten Datensatz springen

  Alt 8. Jun 2010, 21:24
Also NULL kann keines der Felder werden. Siehe Anhang.


Ich werde das von DeddyH mal probieren. Was macht den CONCAT_WS? das kenne ich nicht.

Hm, das liefert gar keine ID.
Miniaturansicht angehängter Grafiken
db.jpg  
Michael
Ein Teil meines Codes würde euch verunsichern.
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

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

AW: Zum nächsten Datensatz springen

  Alt 8. Jun 2010, 21:25
Es hängt mehrere Felder zusammen und fügt ein Trennzeichen dazwischen ein
Markus Kinzler
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

Registriert seit: 17. Sep 2006
Ort: Barchfeld
27.625 Beiträge
 
Delphi 12 Athens
 
#20

AW: Zum nächsten Datensatz springen

  Alt 8. Jun 2010, 21:27
CONCAT_WS hängt die Strings ab Parameter 2 hintereinander, verwendet aber den 1. Parameter als Trenner.
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
Antwort Antwort
Seite 2 von 7     12 34     Letzte »    


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 12:30 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