AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Thema durchsuchen
Ansicht
Themen-Optionen

SQL Berechnung

Ein Thema von Hansi · begonnen am 21. Dez 2004 · letzter Beitrag vom 21. Dez 2004
Antwort Antwort
Seite 1 von 2  1 2      
Hansi

Registriert seit: 8. Okt 2004
271 Beiträge
 
#1

SQL Berechnung

  Alt 21. Dez 2004, 13:12
Hey,

Über folgende Code öffne ich eine SQL-Abfrage.

Delphi-Quellcode:
...
Query1.Active:=False;
Query1.DatabaseName:='.\DB\';
Query1.SQL.Clear;
Query1.SQL.Add('SELECT Datum, Wert FROM Datenbank WHERE Datum BETWEEN :von AND :bis ORDER BY Datum');
Query1.ParamByName('von').AsDate:=StrToDate(Edit1.Text);
Query1.ParamByName('bis').AsDate:=StrToDate(Edit2.Text);
Query1.Open;
...
1. Nun möchte ich auf einen Wert bei einem bestimmten Datum zugreifen. Wie funktioniert dies?

2. Wie kann ich die Summe der Spalte Wert berechnen?
  Mit Zitat antworten Zitat
Benutzerbild von Stevie
Stevie

Registriert seit: 12. Aug 2003
Ort: Soest
4.008 Beiträge
 
Delphi 10.1 Berlin Enterprise
 
#2

Re: SQL Berechnung

  Alt 21. Dez 2004, 13:15
Hi Hansi,

1. Es gibt die Methode Locate von TDataSet, aber du musst schauen, ob sie implementiert ist und funktioniert!
2. Entweder durch die Datenmenge iterieren und summieren oder gleich ne eigene Sql-Abfrage.

MfG
Stevie
Stefan
“Simplicity, carried to the extreme, becomes elegance.” Jon Franklin

Delphi Sorcery - DSharp - Spring4D - TestInsight
  Mit Zitat antworten Zitat
Hansi

Registriert seit: 8. Okt 2004
271 Beiträge
 
#3

Re: SQL Berechnung

  Alt 21. Dez 2004, 13:19
Kannst Du mir bitte für beide Punkte ein Beispiel geben?
  Mit Zitat antworten Zitat
Benutzerbild von Stevie
Stevie

Registriert seit: 12. Aug 2003
Ort: Soest
4.008 Beiträge
 
Delphi 10.1 Berlin Enterprise
 
#4

Re: SQL Berechnung

  Alt 21. Dez 2004, 13:27
1.
Delphi-Quellcode:
begin
  if Query.Locate('DATUM', Datum, []) then
    {...}
end;
2.
Delphi-Quellcode:
begin
  Query.First;
  Summe := 0;
  while not Query.Eof do
  begin
    Summe := Summe + Query.FieldValues['WERT'];
    Query.Next;
  end;
end;
Stefan
“Simplicity, carried to the extreme, becomes elegance.” Jon Franklin

Delphi Sorcery - DSharp - Spring4D - TestInsight
  Mit Zitat antworten Zitat
Hansi

Registriert seit: 8. Okt 2004
271 Beiträge
 
#5

Re: SQL Berechnung

  Alt 21. Dez 2004, 13:35
Super! Vielen Dank!

kann ich das auch so machen?
Query1.SQL.Add('SELECT sum(Wert) FROM Datenbank WHERE Datum BETWEEN :von AND :bis'); Bei mir kommt nämlich die Fehlermeldung: Keine Übereinstimung der Typen im Ausdruck. Was ist falsch?

Ist Deine Variante der Summe schneller als mit SQL?
  Mit Zitat antworten Zitat
Benutzerbild von Stevie
Stevie

Registriert seit: 12. Aug 2003
Ort: Soest
4.008 Beiträge
 
Delphi 10.1 Berlin Enterprise
 
#6

Re: SQL Berechnung

  Alt 21. Dez 2004, 13:38
Ich denke, SQL wird schneller sein!
Von welchem Datentyp ist den Wert?
Stefan
“Simplicity, carried to the extreme, becomes elegance.” Jon Franklin

Delphi Sorcery - DSharp - Spring4D - TestInsight
  Mit Zitat antworten Zitat
Hansi

Registriert seit: 8. Okt 2004
271 Beiträge
 
#7

Re: SQL Berechnung

  Alt 21. Dez 2004, 13:41
Währung!


Edit: In Datenbank war String nicht Währung eingestellt!
  Mit Zitat antworten Zitat
Hansi

Registriert seit: 8. Okt 2004
271 Beiträge
 
#8

Re: SQL Berechnung

  Alt 21. Dez 2004, 13:54
Wie bekomme ich die "SQL-Summe" mit INSERT INTO in die Datenbank, und zwar an eine ganz bestimmte Stelle(wo Datum =... ist!)?
  Mit Zitat antworten Zitat
Benutzerbild von Stevie
Stevie

Registriert seit: 12. Aug 2003
Ort: Soest
4.008 Beiträge
 
Delphi 10.1 Berlin Enterprise
 
#9

Re: SQL Berechnung

  Alt 21. Dez 2004, 13:55
Zitat von Hansi:
Wie bekomme ich die "SQL-Summe" mit INSERT INTO in die Datenbank, und zwar an eine ganz bestimmte Stelle(wo Datum =... ist!)?
Was willst du genau machen?
Stefan
“Simplicity, carried to the extreme, becomes elegance.” Jon Franklin

Delphi Sorcery - DSharp - Spring4D - TestInsight
  Mit Zitat antworten Zitat
Hansi

Registriert seit: 8. Okt 2004
271 Beiträge
 
#10

Re: SQL Berechnung

  Alt 21. Dez 2004, 14:01
Summe von Wert in einem bestimmten Zeitraum

Bsp:
Summe von Wert zwischen dem 1.10. bis 1.11.
Die Summe in DB an die Stelle 1.11. schreiben
  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 12:44 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