AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi Ausgabe der Daten 2er Tabellen statt einer
Thema durchsuchen
Ansicht
Themen-Optionen

Ausgabe der Daten 2er Tabellen statt einer

Ein Thema von youuu · begonnen am 16. Aug 2009 · letzter Beitrag vom 16. Aug 2009
Antwort Antwort
Seite 1 von 2  1 2      
youuu

Registriert seit: 2. Sep 2008
Ort: Kleve
822 Beiträge
 
Delphi 2010 Professional
 
#1

Ausgabe der Daten 2er Tabellen statt einer

  Alt 16. Aug 2009, 17:24
Datenbank: MySQL • Zugriff über: Devarts
Hi,

Momentan löse ich es so:

Delphi-Quellcode:
QueryRead.SQL.Text:='SELECT * FROM `'contacts+'` WHERE Customer_number = '''+customer_number+'''';
QueryRead.Open;

position:= FormMain.QueryRead.FieldByName('position').AsWideString;

QueryRead.Close;
Wie kann ich es realisieren wenn ich aber die Werte von 2 Tabellen haben möchte statt nur einer?

also z.B.
Delphi-Quellcode:
QueryRead.SQL.Text:='SELECT * FROM `'contacts+'` [b] And `'contacts2'[/b]` WHERE Customer_number = '''+customer_number+'''';
QueryRead.Open;

position:= FormMain.QueryRead.FieldByName('position').AsWideString; (Tabelle1)
position:= FormMain.QueryRead.FieldByName('position').AsWideString; (Tabelle2)

QueryRead.Close;
Oder muss ich das seperat ausführen?
Steven
  Mit Zitat antworten Zitat
Jürgen Thomas

Registriert seit: 13. Jul 2006
Ort: Berlin
750 Beiträge
 
#2

Re: Ausgabe der Daten 2er Tabellen statt einer

  Alt 16. Aug 2009, 17:31
Mit UNION können zwei SELECT-Ergebnisse in eines zusammengefasst und "am Stück" zurückgegeben werden.

Übrigens ist dein Verfahren, einen SQL-Text per String-Verknüpfung zu erstellen, ziemlich miserabel. Du hast schon Probleme mit den Hochkommata; wie soll das erst bei Zahlen und Datumsformaten werden - ganz abgesehen von SQL-Injection. Dafür sind unbedingt Parameter zu verwenden.

Gruß Jürgen
#D mit C# für NET, dazu Firebird
früher: Delphi 5 Pro, Delphi 2005 Pro mit C# (also NET 1.1)
Bitte nicht sauer sein, wenn ich mich bei Delphi-Schreibweisen verhaue; ich bin inzwischen an C# gewöhnt.
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

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

Re: Ausgabe der Daten 2er Tabellen statt einer

  Alt 16. Aug 2009, 17:34
Oder einem Join
Markus Kinzler
  Mit Zitat antworten Zitat
Benutzerbild von jfheins
jfheins

Registriert seit: 10. Jun 2004
Ort: Garching (TUM)
4.579 Beiträge
 
#4

Re: Ausgabe der Daten 2er Tabellen statt einer

  Alt 16. Aug 2009, 17:35
So in etwa:
select * from table1, table2 where id = 10 also einfach mit Kommas trennen.

Btw.: du brauchst die Backticks nicht unbedingt

P.S.: Parameter sind wirklich besser als Stringverkettung. Solltest du dir mal anschauen
  Mit Zitat antworten Zitat
youuu

Registriert seit: 2. Sep 2008
Ort: Kleve
822 Beiträge
 
Delphi 2010 Professional
 
#5

Re: Ausgabe der Daten 2er Tabellen statt einer

  Alt 16. Aug 2009, 17:39
Zitat von Jürgen Thomas:
Mit UNION können zwei SELECT-Ergebnisse in eines zusammengefasst und "am Stück" zurückgegeben werden.

Übrigens ist dein Verfahren, einen SQL-Text per String-Verknüpfung zu erstellen, ziemlich miserabel. Du hast schon Probleme mit den Hochkommata; wie soll das erst bei Zahlen und Datumsformaten werden - ganz abgesehen von SQL-Injection. Dafür sind unbedingt Parameter zu verwenden.

Gruß Jürgen
Das war gerade ein kleines Bsp. normal erfolgt alles über Parameter.
Steven
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

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

Re: Ausgabe der Daten 2er Tabellen statt einer

  Alt 16. Aug 2009, 17:41
... WHERE Customer_number = :customer_number ...
Markus Kinzler
  Mit Zitat antworten Zitat
youuu

Registriert seit: 2. Sep 2008
Ort: Kleve
822 Beiträge
 
Delphi 2010 Professional
 
#7

Re: Ausgabe der Daten 2er Tabellen statt einer

  Alt 16. Aug 2009, 17:45
Zitat von jfheins:
So in etwa:
select * from table1, table2 where id = 10
Wie kann ich die einkommenden Werte dann unterscheiden, wenn der Wert in beiden Tabellen existiert.
Steven
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

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

Re: Ausgabe der Daten 2er Tabellen statt einer

  Alt 16. Aug 2009, 17:51
Durch Aliasing zudem brauchst du ja nur die Spalten abfragen, welche du benötigst.

SQL-Code:
Select
    t1.position as pos1, t2.position as pos2
...
Markus Kinzler
  Mit Zitat antworten Zitat
youuu

Registriert seit: 2. Sep 2008
Ort: Kleve
822 Beiträge
 
Delphi 2010 Professional
 
#9

Re: Ausgabe der Daten 2er Tabellen statt einer

  Alt 16. Aug 2009, 18:01
Naja das sind knapp 20-30 Werte, wird das dann nicht etwas lang und unübersichtlich?
Steven
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

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

Re: Ausgabe der Daten 2er Tabellen statt einer

  Alt 16. Aug 2009, 18:09
Brauchst du den alle?
Sonst würden die Spalten verschiedene Postfixes bekommen
Markus Kinzler
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 1 von 2  1 2      


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 01:50 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