AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi Wieviele Querys braucht man
Thema durchsuchen
Ansicht
Themen-Optionen

Wieviele Querys braucht man

Ein Thema von Flogo · begonnen am 15. Jul 2005 · letzter Beitrag vom 16. Jul 2005
Antwort Antwort
Benutzerbild von Flogo
Flogo

Registriert seit: 24. Mär 2003
Ort: Freiburg im Breisgau
317 Beiträge
 
Delphi 7 Professional
 
#1

Wieviele Querys braucht man

  Alt 15. Jul 2005, 10:56
Datenbank: Access • Version: 2000 • Zugriff über: ADO
Diese Frage klingt vielleicht etwas dumm aber es geht um folgendes:

Ich versuche mich grade mit einem Buch (Datenbankprogrammierung mit Delphi 6) in Datenbanken einzuarbeiten.
In diesem Buch steht man brauch für jede Operation (Insert, Update, Delete, GetByPK, GetByName, ....)
und für jede Tabelle eine Query. Also (QRY_InsertLand, QRYUpdateLand, ..., QRY_InsertKunde, QRY_UpdateKunde, ....)

Zu jeder Tabelle die nicht nur aus Pflichtfeldern besteht, muss man außerdem noch Prozeduren schreiben, die erstmal das SQL-Statement zusammenbasteln.

Hat das einen tieferen Sinn? Kan man nicht einfach eine Query pro Operation machen und je eine Prozedur, die die SQL-Statements bastelt?
If one coincidence can occur, then another coincidence can occur. And if one coincidence happens to occur just after another coincidence, then that is just a coincidence.
DNA

www.Anyxist.de
  Mit Zitat antworten Zitat
Benutzerbild von Bernhard Geyer
Bernhard Geyer

Registriert seit: 13. Aug 2002
17.197 Beiträge
 
Delphi 10.4 Sydney
 
#2

Re: Wieviele Querys braucht man

  Alt 15. Jul 2005, 11:02
Zitat von Flogo:
Diese Frage klingt vielleicht etwas dumm aber es geht um folgendes:

Ich versuche mich grade mit einem Buch (Datenbankprogrammierung mit Delphi 6) in Datenbanken einzuarbeiten.
In diesem Buch steht man brauch für jede Operation (Insert, Update, Delete, GetByPK, GetByName, ....)
und für jede Tabelle eine Query. Also (QRY_InsertLand, QRYUpdateLand, ..., QRY_InsertKunde, QRY_UpdateKunde, ....)

Zu jeder Tabelle die nicht nur aus Pflichtfeldern besteht, muss man außerdem noch Prozeduren schreiben, die erstmal das SQL-Statement zusammenbasteln.

Hat das einen tieferen Sinn? Kan man nicht einfach eine Query pro Operation machen und je eine Prozedur, die die SQL-Statements bastelt?
Freilich Machen das selbst genauso. Haben es auch noch so aufgebaut das mittels Bridge-Pattern mehrer DB-System unterstützt werden.
Windows Vista - Eine neue Erfahrung in Fehlern.
  Mit Zitat antworten Zitat
Benutzerbild von Sharky
Sharky

Registriert seit: 29. Mai 2002
Ort: Frankfurt
8.252 Beiträge
 
Delphi 2006 Professional
 
#3

Re: Wieviele Querys braucht man

  Alt 15. Jul 2005, 11:06
Hai Flogo,

ich würde die Frage jetzt ersteinmal so beantworten:

Du brauchst für jede Tabelle auf die gleichzeitig zugegriffen wird ein eigenes Query.

Beispie:
Du hast 2 DBGrid die den Inhalt aus zwei Tabellen anzeigen und noch einige DBEdits die den Inhalt aus einer dritten Tabelle anzeigen. In diesem Fall brauchst Du 3 Querys.

Wenn Du jetzt noch zusätzliche Operationen (Insert,Update..) mit irgendeiner der drei Tabellen durchführen möchtest brauchst Du ein zusätzliches Query.

Es kann aber unter umständen besser sein für die "zusatz Operationen" mehrere Querys zu verwenden. Dies ergibt sich aber erst aus den Anforderungen des Programmes.


Wenn Du aber nur ein DBGrid hast in dem, z.B durch auswahl in einer ComboBox, der Inhalt von verschiedenen Tabellen angezeigt werden soll (nicht gleichzeitig) brauchst Du auch nur ein Query für das ganze.
Stephan B.
"Lasst den Gänsen ihre Füßchen"
  Mit Zitat antworten Zitat
Benutzerbild von Flogo
Flogo

Registriert seit: 24. Mär 2003
Ort: Freiburg im Breisgau
317 Beiträge
 
Delphi 7 Professional
 
#4

Re: Wieviele Querys braucht man

  Alt 15. Jul 2005, 11:09
Zitat von Bernhard Geyer:
Freilich
bezieht sich das auf "macht das Sinn?" oder auf "Kann man das anders machen?"


Zitat von Bernhard Geyer:
Machen das selbst genauso. Haben es auch noch so aufgebaut das mittels Bridge-Pattern mehrer DB-System unterstützt werden.
Was sind Bridge-Pattern?


Ein möglicher Grund für die Art aus dem Buch ist mir noch eingefallen:
Was passiert, wenn während einer Abfrage eine andere gestartet wird? Ist dann die Query nicht "belegt"?


[Edit]
@Sharky
Danke! Das hab ich vorhin noch nicht gesehen.
Das heißt dann wohl ich muss erstmal meine Oberflläche entwerfen.

Wie ist das wenn ich mehrere Tabellen auf unterschiedlichen Tabsheets habe? Die kann ich dann doch behandeln wie unabhängige Tabellen, oder?
[/Edit]

[Edit2]
Wie ist das mit Verknüpfungstabellen? also Tabellen die eine n-zu-n-Verbindung in zwei 1-zu-n-Verbindungen auflösen?
[/Edit2]
If one coincidence can occur, then another coincidence can occur. And if one coincidence happens to occur just after another coincidence, then that is just a coincidence.
DNA

www.Anyxist.de
  Mit Zitat antworten Zitat
Benutzerbild von Bernhard Geyer
Bernhard Geyer

Registriert seit: 13. Aug 2002
17.197 Beiträge
 
Delphi 10.4 Sydney
 
#5

Re: Wieviele Querys braucht man

  Alt 15. Jul 2005, 11:27
Zitat von Flogo:
Zitat von Bernhard Geyer:
Freilich
bezieht sich das auf "macht das Sinn?" oder auf "Kann man das anders machen?"
Man wird, wenn man komplexere DB-Anwendungen entwickelt sich nicht mehr auf DB-Sensitive Controls und gebundene Datenmenge verlassen sondern alles "per Hand" erledigt.

Zitat von Flogo:
Zitat von Bernhard Geyer:
Machen das selbst genauso. Haben es auch noch so aufgebaut das mittels Bridge-Pattern mehrer DB-System unterstützt werden.
Was sind Bridge-Pattern?
Brücken-Muster

Zitat von Flogo:
Ein möglicher Grund für die Art aus dem Buch ist mir noch eingefallen:
Was passiert, wenn während einer Abfrage eine andere gestartet wird? Ist dann die Query nicht "belegt"?
Ja. Deshalb mußt du in solch einen Fall mit mehreren arbeiten. Aber ich les ja eh alles immer aus den Queries in eigene Objekte/Klassen.
Windows Vista - Eine neue Erfahrung in Fehlern.
  Mit Zitat antworten Zitat
Igotcha

Registriert seit: 22. Dez 2003
544 Beiträge
 
Delphi 2006 Professional
 
#6

Re: Wieviele Querys braucht man

  Alt 15. Jul 2005, 11:40
Es kommt grds. darauf an, was Dein Programm machen soll.

Beispiel:

Du möchtest 2 Listviews mit Tabelleneinträgen füllen.

Dann reicht ein Query-Objekt, welches nacheinander 2 Abfragen durchführt, um die Listviews zu füllen.

Arbeiten tut das Programm dann mit den Daten, die im Listview stehen, da haben die Queries nichts mehr mit zu tun. Natürlich kann man bei Doppelklick auf einen Eintrag eine neue Query starten, um z.B. einen dritten LV, o.ä. zu bedienen.

Ich benutze zum Vorbelegen von Auswahlelementen in Formularen grds. nur eine Query, mit denen ich z.B: Dropdownlisten, etc. fülle. Dies mache ich mit der AddObject-Methode, wo dann gleich die DB-ID eines Eintrags mitgeliefert wird. Findet jetzt eine Useraktion statt, z.B. eine Dropdownlisten-Auswahl, frage ich die ID des Objekts ab und übergebe diese an ein (neues) Query-Objekt.


Anderes Beispiel:

In einer meiner Anwendungen muss ich für einen bestimmten Vorgang zur Darstellung von DB-Informationen 2 Query-Objekte verwenden.

Das sieht dann ungefähr so aus:

Delphi-Quellcode:
Query1.SQL.Text:='.....';
Query1.Open;
While not Query1.Eof do
begin
       Query2.SQL.Text:='.......';
       Query2.ParamByName('myParameter').AsString:=Query1.FieldByName('dummy').AsString;
       Query2.Open;
       While not Query2.Eof do
       begin
          Tueetwas mit den Daten aus Query2;
       end;
end;
In diesem Beispiel braucht man 2 Query-Objekte, da während des Vorgangs auch 2 Datenquellen benötigt werden.

Gruß Igotcha
  Mit Zitat antworten Zitat
Benutzerbild von Flogo
Flogo

Registriert seit: 24. Mär 2003
Ort: Freiburg im Breisgau
317 Beiträge
 
Delphi 7 Professional
 
#7

Re: Wieviele Querys braucht man

  Alt 15. Jul 2005, 11:48
Sorry ich glaub das ist zu hoch für mich.
Ich hab immer noch nicht verstanden ob das "per Hand" erledigen jetzt für eine oder viele Query spricht.
Mit dem Wikipedia-Artikel fange ich auch nicht so viel an, weil ich mich zum einen nicht mit diesen Diagrammen auskenne und zum anderen die praktische Umsetzung dieses Prinzips in einer Datenbank nur erahnen kann.
Zitat:
Deshalb mußt du in solch einen Fall mit mehreren arbeiten. Aber ich les ja eh alles immer aus den Queries in eigene Objekte/Klassen.
Was tun diese Klassen dann mit den Daten? Ich hatte vor die Daten per Query in Records zu lesen, aber das würde die Frage nach den Querys ja nicht beantworten.


[Edit]
@Igotcha
Vielen Dank! Ich glaube zusammen mit Sharkys Post ist das genau das was ich wissen wollte.

[/Edit]
If one coincidence can occur, then another coincidence can occur. And if one coincidence happens to occur just after another coincidence, then that is just a coincidence.
DNA

www.Anyxist.de
  Mit Zitat antworten Zitat
Benutzerbild von Bernhard Geyer
Bernhard Geyer

Registriert seit: 13. Aug 2002
17.197 Beiträge
 
Delphi 10.4 Sydney
 
#8

Re: Wieviele Querys braucht man

  Alt 15. Jul 2005, 20:37
Zitat von Flogo:
Was tun diese Klassen dann mit den Daten? Ich hatte vor die Daten per Query in Records zu lesen, aber das würde die Frage nach den Querys ja nicht beantworten.
Wenn Du z.B eine einfache Adressveraltung hast. So könntest Du jeden Tabelleneintrag als Instanz einer Klasse TAdresse repräsendieren wobei diese Klasse sich sowohl speichern als auch laden könnte. Willst Du jetzt alle "Müllers" auslesen so bekommst du von deiner DB-Schnittstelle eine Objektliste von TAdresse (z.B in einer Klasse TAdressen). In dieser Klasse hast du z.B. eine Methode MakeSerienbrief um z.B. einen Serienbrief zu erzeugen.
Windows Vista - Eine neue Erfahrung in Fehlern.
  Mit Zitat antworten Zitat
Benutzerbild von Flogo
Flogo

Registriert seit: 24. Mär 2003
Ort: Freiburg im Breisgau
317 Beiträge
 
Delphi 7 Professional
 
#9

Re: Wieviele Querys braucht man

  Alt 16. Jul 2005, 09:28
Ahhh! Ich glaub jetzt hab ichs verstanden
Wäre die Query in dem Fall dann Teil der Klasse TAdresse?
If one coincidence can occur, then another coincidence can occur. And if one coincidence happens to occur just after another coincidence, then that is just a coincidence.
DNA

www.Anyxist.de
  Mit Zitat antworten Zitat
Benutzerbild von r_kerber
r_kerber

Registriert seit: 11. Feb 2003
Ort: Trittau
3.538 Beiträge
 
Delphi XE Professional
 
#10

Re: Wieviele Querys braucht man

  Alt 16. Jul 2005, 10:43
Zitat von Flogo:
Wäre die Query in dem Fall dann Teil der Klasse TAdresse?
Ich würde Datenbankklasse (mit Query) und Fachklasse (TAdressen) strikt voneinander trennen. Also in etwa so:
  • DB-Abfrage mit Query
  • Fachklasse mit Daten befüllen (Getter/Setter)
Dann ist es der Adressenklasse völlig egal, wo die Adreßdaten herkommen (DB, XML, SOAP, Text-Datei, manuelle Eingabe, ...)
  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 19:26 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