AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi Division in Firebird SQL Abfrage
Thema durchsuchen
Ansicht
Themen-Optionen

Division in Firebird SQL Abfrage

Ein Thema von OS299 · begonnen am 18. Nov 2008 · letzter Beitrag vom 18. Nov 2008
Antwort Antwort
Seite 1 von 2  1 2      
OS299

Registriert seit: 19. Apr 2008
Ort: Fellbach
9 Beiträge
 
#1

Division in Firebird SQL Abfrage

  Alt 18. Nov 2008, 10:25
Datenbank: Firebird • Version: 2.0 • Zugriff über: SQL
Hallo ich möchte eine Division aus zwei inline Selects durchführen, bekomme aber eine Fehlermeldung, addieren und multiplizieren funktioniert einwandfrei. Vielleicht kann mir jemand helfen?

SQL-Code:
select VV.Kontakt, AK.Name,

       (select Count(VVI.Counter)
          From Vor_Vorgang VVI
          Where VVI.Vorgangsart = 30 and VVI.Kontakt = VV.Kontakt
           and VVI.DATUM >=:Z1 AND VVI.DATUM <=:Z2) as Angebot,

       (select Count(VVI.Counter)
         From Vor_Vorgang VVI
         Where VVI.Vorgangsart = 20 and VVI.Kontakt = VV.Kontakt
           and VVI.DATUM >=:Z1 AND VVI.DATUM <=:Z2) as Auftrag,

       (select Cast(Count(VVI.Counter)as Numeric(15,2))
          From Vor_Vorgang VVI
          Where VVI.Vorgangsart = 30 and VVI.Kontakt = VV.Kontakt
           and VVI.DATUM >=:Z1 AND VVI.DATUM <=:Z2)

           / <<<< Hier die Division

       (select Cast(Count(VVI.Counter)as Numeric(15,2))
         From Vor_Vorgang VVI
         Where VVI.Vorgangsart = 20 and VVI.Kontakt = VV.Kontakt
          and VVI.DATUM >=:Z1 AND VVI.DATUM <=:Z2)



From Vor_Vorgang VV
Left Join ADR_Kontakt AK on AK.Counter = VV.Kontakt
Where VV.DATUM >=:Z1 AND VV.DATUM <=:Z2
Group By VV.Kontakt, AK.Name
Order By AK.Name
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

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

Re: Division in Firebird SQL Abfrage

  Alt 18. Nov 2008, 10:26
Welcher Fehler wird gemeldet?
Markus Kinzler
  Mit Zitat antworten Zitat
OS299

Registriert seit: 19. Apr 2008
Ort: Fellbach
9 Beiträge
 
#3

Re: Division in Firebird SQL Abfrage

  Alt 18. Nov 2008, 10:28
http://img3.imagebanana.com/img/6f8e...ov.1811.27.jpg
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

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

Re: Division in Firebird SQL Abfrage

  Alt 18. Nov 2008, 10:30
Kann das sein, dass da nur 2 Klammern fehlen?
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
 
#5

Re: Division in Firebird SQL Abfrage

  Alt 18. Nov 2008, 10:30
Versuch mal
SQL-Code:
...
 Cast((select Cast(Count(VVI.Counter)as Numeric(15,2))
          From Vor_Vorgang VVI
          Where VVI.Vorgangsart = 30 and VVI.Kontakt = VV.Kontakt
           and VVI.DATUM >=:Z1 AND VVI.DATUM <=:Z2)

           / <<<< Hier die Division

       (select Cast(Count(VVI.Counter)as Numeric(15,2))
         From Vor_Vorgang VVI
         Where VVI.Vorgangsart = 20 and VVI.Kontakt = VV.Kontakt
          and VVI.DATUM >=:Z1 AND VVI.DATUM <=:Z2) as Numeric(15,2))
...
Markus Kinzler
  Mit Zitat antworten Zitat
Gruber_Hans_12345

Registriert seit: 14. Aug 2004
1.426 Beiträge
 
Delphi 2007 Professional
 
#6

Re: Division in Firebird SQL Abfrage

  Alt 18. Nov 2008, 10:31
eventuell ein explizieter CAST in DOUBLE PRECISION der einzelnen Felder?
Gruss Hans

2B or not 2B, that is FF
  Mit Zitat antworten Zitat
OS299

Registriert seit: 19. Apr 2008
Ort: Fellbach
9 Beiträge
 
#7

Re: Division in Firebird SQL Abfrage

  Alt 18. Nov 2008, 10:37
Zitat von mkinzler:
Versuch mal
SQL-Code:
...
 Cast((select Cast(Count(VVI.Counter)as Numeric(15,2))
          From Vor_Vorgang VVI
          Where VVI.Vorgangsart = 30 and VVI.Kontakt = VV.Kontakt
           and VVI.DATUM >=:Z1 AND VVI.DATUM <=:Z2)

           / <<<< Hier die Division

       (select Cast(Count(VVI.Counter)as Numeric(15,2))
         From Vor_Vorgang VVI
         Where VVI.Vorgangsart = 20 and VVI.Kontakt = VV.Kontakt
          and VVI.DATUM >=:Z1 AND VVI.DATUM <=:Z2) as Numeric(15,2))
...
Ne gleiche Fehlermeldung ! Hatte diese Methode auch schonmal getestet.
Divisionen zweier Inlineselects sind aber im Grunde möglich oder?
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

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

Re: Division in Firebird SQL Abfrage

  Alt 18. Nov 2008, 10:38
Sollte möglich sein. Versuch es mal wie hans vorgeschlagen hat, jedes Teilergebnis zu Casten
Markus Kinzler
  Mit Zitat antworten Zitat
OS299

Registriert seit: 19. Apr 2008
Ort: Fellbach
9 Beiträge
 
#9

Re: Division in Firebird SQL Abfrage

  Alt 18. Nov 2008, 10:41
SQL-Code:
       (select Cast(Count(VVI.Counter)as DOUBLE PRECISION)
          From Vor_Vorgang VVI
          Where VVI.Vorgangsart = 30 and VVI.Kontakt = VV.Kontakt
           and VVI.DATUM >=:Z1 AND VVI.DATUM <=:Z2)

           /

       (select Cast(Count(VVI.Counter)as DOUBLE PRECISION)
         From Vor_Vorgang VVI
         Where VVI.Vorgangsart = 20 and VVI.Kontakt = VV.Kontakt
          and VVI.DATUM >=:Z1 AND VVI.DATUM <=:Z2)
Habe es jetzt mal so versucht, auch Fehlermeldung. Aber eigentlich dürfte ja auch nur ganze Zahlen herauskommen, ich counte ja.
  Mit Zitat antworten Zitat
nahpets
(Gast)

n/a Beiträge
 
#10

Re: Division in Firebird SQL Abfrage

  Alt 18. Nov 2008, 10:50
Hallo,

wenn nur ganze Zahlen rauskommen, warum dann der Cast auf das Count (um hier eventuell bei der Division Nachkommastellen zu bekommen)?
Wie groß werden denn die Werte, die beim Count herauskommen?
  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 23:37 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