![]() |
Datenbank: Firebird • Version: 2,5,5 • Zugriff über: IBO / IBExpert
Verschachtelte SQL Abfrage
Liste der Anhänge anzeigen (Anzahl: 1)
Hallo SQL Spezis,
ich habe eine Tabelle (Buchhaltung) worin es die Felder Kontonummer und Gegenkontonummer gibt. Ich möchte nun in einem SQL Statement ermitteln alle Kontonummern und Gegenkontonummer die in den Datensätzen vorkommt. Für die Kontonummer ist es einfach.
Delphi-Quellcode:
Wir mache ich es aber mit Kontonummer und Gegenkontonummer.
SELECT Kontonummer, COUNT(Kontonummer)
FROM tbl_buchhaltung GROUP BY Kontonummer HAVING ( COUNT(Kontonummer) > 0 ) Jedes Konto darf als Ergebnis nur einmal vorkommen. (siehe Anlage) |
AW: Verschachtelte SQL Abfrage
so ungefähr
Code:
select kontonummer, sum(anzahl) from (
seölct kontonummer, count(*) as Anzahl from tabelle group by kontonummer union all seölct gegenkontonummer, count(*) from tabelle group by gegenkontonummer ) x |
AW: Verschachtelte SQL Abfrage
SQL-Code:
select
distinct konto from ( select distict konto from <tabelle> union select distinct gegenkonto as konto from <Tabelle> ); |
AW: Verschachtelte SQL Abfrage
Den Union-Ansatz würde ich auch wählen, ich verstehe die Aufgabe so, dass alle Konten herausgefunden werden sollen, egal ob sie als Konto oder als Gegenkonto verwendet wurden.
Allerdings kann man sich hier den Subselect sparen, da der Union als default ein UNION DISTINCT ist.
SQL-Code:
select distinct konto from tbl_buchhaltung
union select gegenkonto from tbl_buchhaltung |
AW: Verschachtelte SQL Abfrage
Soll denn nicht gezählt werden?
|
AW: Verschachtelte SQL Abfrage
Ist m.E. nicht notwendig. Dient wohl nur dazu Dupletten auszufiltern, was durch das DISTINCT ja gemacht werden sollte.
|
AW: Verschachtelte SQL Abfrage
Zitat:
Gruß K-H |
AW: Verschachtelte SQL Abfrage
Zitat:
|
AW: Verschachtelte SQL Abfrage
benötigt wird wie es mkinzler schon geschrieben hat.
|
AW: Verschachtelte SQL Abfrage
Bei diesen Statement:
Delphi-Quellcode:
kommt diese Fehlermeldung:
select
distinct kontonummer from ( select distinct kontonummer from tbl_buchhaltung union select distinct gegenkontonummer as kontonummer from tbl_buchhaltung ); Invalid token. Dynamic SQL Error. SQL error code = -104. Token unknown - line 1, column 1. distinct |
Alle Zeitangaben in WEZ +1. Es ist jetzt 22:41 Uhr. |
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024-2025 by Thomas Breitkreuz