AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken NVL, NZ - aber was in Local SQL unter Paradox?
Thema durchsuchen
Ansicht
Themen-Optionen

NVL, NZ - aber was in Local SQL unter Paradox?

Offene Frage von "Ticino"
Ein Thema von Ticino · begonnen am 14. Mär 2005 · letzter Beitrag vom 18. Mär 2005
Antwort Antwort
Ticino

Registriert seit: 14. Mär 2005
4 Beiträge
 
#1

NVL, NZ - aber was in Local SQL unter Paradox?

  Alt 14. Mär 2005, 19:30
Datenbank: Paradox • Version: 7? • Zugriff über: Tquery / Local SQL
Hallo zusammen

Ich verwende Paradox für eine grössere Applikation.
Dabei habe ich das Problem nicht existierender Werte,
(Z.B. Rechnungen ohne Zahlungen) möchte aber trotzdem
Berechnungen damit durchführen.

In ORACLE gibt's für diesen Zweck die Funktion NVL, in
ACCESS die Funktion NZ. Welche Möglichkeit existiert für
Local SQL unter Paradox ? Vielleicht auch Work around ?

Grüsse und besten Dank für Ideen.
  Mit Zitat antworten Zitat
Benutzerbild von Jelly
Jelly

Registriert seit: 11. Apr 2003
Ort: Moestroff (Luxemburg)
3.741 Beiträge
 
Delphi 2007 Professional
 
#2

Re: NVL, NZ - aber was in Local SQL unter Paradox?

  Alt 14. Mär 2005, 22:35
Zitat von Ticino:
Ich verwende Paradox für eine grössere Applikation.
Was ist denn groß ?
Zitat von Ticino:
Dabei habe ich das Problem nicht existierender Werte,
(Z.B. Rechnungen ohne Zahlungen) möchte aber trotzdem
Berechnungen damit durchführen.
Es wäre hilfreich zu wissen, wie erstens deine Datenstruktur aussieht, und was du überhaupt berechnen willst... Hier im Forum tummeln sich zwar viele schlaue Köpfe, aber Hellseher hab ich hier noch keine angetroffen.

Zitat von Ticino:
In ORACLE gibt's für diesen Zweck die Funktion NVL, in
ACCESS die Funktion NZ. Welche Möglichkeit existiert für
Local SQL unter Paradox ? Vielleicht auch Work around ?
Evenetuell interpretiert Paradox die NULL Felder als 0-Wert. Probiers doch mal aus, was dir folgendes Statement liefert... (sorry, ich benutze kein Paradox, was seine Gründe hat):
select null+1
  Mit Zitat antworten Zitat
Benutzerbild von MrSpock
MrSpock
(Co-Admin)

Registriert seit: 7. Jun 2002
Ort: Owingen
5.865 Beiträge
 
Delphi 2010 Professional
 
#3

Re: NVL, NZ - aber was in Local SQL unter Paradox?

  Alt 14. Mär 2005, 23:42
die Frage hab ich doch schonmal gelesen

probier mal:
SQL-Code:
SELECT Rechnungen.Betrag – Zahlungen.Betrag AS Restbetrag
WHERE Zahlungen.Betrag IS NOT NULL
UNION
SELECT Rechnungen.Betrag AS Restbetrag
WHERE Zahlungen.Betrag IS NULL
Albert
Live long and prosper


MrSpock
  Mit Zitat antworten Zitat
Ticino

Registriert seit: 14. Mär 2005
4 Beiträge
 
#4

Re: NVL, NZ - aber was in Local SQL unter Paradox?

  Alt 15. Mär 2005, 20:42
Hallo zusammen

Mit Grösse der Applikation meine ich: ich möchte die Appl. vorderhand nicht auf eine andere
Datenbank (jetzt PARADOX) umschreiben, obwohl ich langsam aber sicher genug von PARADOX habe.

Es geht um etwas ganz einfaches, nämlich die Bestimmung des noch zu bezahlenden Betrages von Rechnungen bei mehreren Teilzahlungen (auch 0).

Im folgenden nun eine Abfrage wie sie unter ACCESS läuft:

SQL-Code:
SELECT Rechnungen.Rechnungsnummer, Rechnungen.Betrag, Sum(NZ([Zahlungen].[Betrag],0)) AS [Summe Zahlungen], [Rechnungen].[Betrag]-Sum(NZ([Zahlungen].[Betrag],0)) AS Restbetrag
FROM Rechnungen LEFT JOIN Zahlungen ON Rechnungen.Rechnungsnummer = Zahlungen.Rechnungsnummer
GROUP BY Rechnungen.Rechnungsnummer, Rechnungen.Betrag;
Wird die Funktion NZ durch NVL ersetzt, ist die Abfrage wahrscheinlich auch unter ORACLE lauffähig.

In PARADOX bedeutet NULL wirklich nicht vorhanden/definiert und wird nicht als 0 interpretiert.

Nun die Idee mit dem UNION funktioniert tatsächlich, wenn auch sehr umständlich:

SQL-Code:
SELECT Rechnungen.Rechnungsnummer, Rechnungen.Betrag, SUM(Zahlungen.Betrag) AS ZSum,
       Rechnungen.Betrag - SUM(Zahlungen.Betrag) AS Restbetrag
FROM Rechnungen, Zahlungen
WHERE (Rechnungen.Rechnungsnummer = Zahlungen.Rechnungsnummer)
GROUP BY Rechnungen.Rechnungsnummer, Rechnungen.Betrag

UNION

SELECT Rechnungen.Rechnungsnummer, Rechnungen.Betrag, 0, Rechnungen.Betrag
FROM Rechnungen
WHERE NOT EXISTS
      (SELECT Zahlungen.Rechnungsnummer FROM Zahlungen
       WHERE (Rechnungen.Rechnungsnummer = Zahlungen.Rechnungsnummer))

ORDER BY Rechnungen.Rechnungsnummer
Nun dies ist Mal eine Lösung. Der erste SELECT in der UNION wird recht schnell ausgeführt, der zweite
ist leider furchtbar langsam. Ich kenne den Grund nicht, vielleicht hat jemand eine Idee. Für Zahlungen.Rechnungsnummer ist kein Index vorhanden ??

Ich kann mir vorstellen, dass man den 2. Select noch umschreiben kann (aus dem ersten abgeleitet) und
damit auf eine wesentlich schnellere Implementation erreicht.

Bin für Anregungen weiterhin dankbar.

Gruss Ticino
  Mit Zitat antworten Zitat
Ticino

Registriert seit: 14. Mär 2005
4 Beiträge
 
#5

Re: NVL, NZ - aber was in Local SQL unter Paradox?

  Alt 15. Mär 2005, 20:50
Evtl. lässt sich mit COUNT etwas anstellen, denn im einen Fall ist COUNT(Zahlungen.Rechnungsnummer) = 0.
  Mit Zitat antworten Zitat
Ticino

Registriert seit: 14. Mär 2005
4 Beiträge
 
#6

Re: NVL, NZ - aber was in Local SQL unter Paradox?

  Alt 18. Mär 2005, 14:57
Habe eine komplizierte Lösung gefunden und werde sie später hier veröffentlichen.
Beim weiteren Ausbau der SQL-Abfrage bin ich aber auf neue Probleme gestossen und
werde vorerst nach neuen Wegen suchen. => Gestaffelte SQL-Abfragen

Vorerst vielen Dank und Gruss

Ticino
  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 08:38 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