AGB  ·  Datenschutz  ·  Impressum  







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

Datensatz immer ausgeben

Ein Thema von pustekuchen · begonnen am 1. Dez 2010 · letzter Beitrag vom 2. Dez 2010
Antwort Antwort
Seite 2 von 2     12   
Benutzerbild von joachimd
joachimd
Online

Registriert seit: 17. Feb 2005
Ort: Weitingen
679 Beiträge
 
Delphi 12 Athens
 
#11

AW: Datensatz immer ausgeben

  Alt 2. Dez 2010, 10:34
So müsste das doch auch gehen:

SQL-Code:
SELECT DISTINCT COUNT(gerichte.restaurant_id) AS Anzahl, restaurants.id AS Id
FROM restaurants,bestellungen,gerichte
WHERE bestellungen.gericht_id = gerichte.id
AND gerichte.restaurant_id = restaurants.id
AND (bestellungen.datum = CURRENT_DATE OR bestellungen.datum is null)
GROUP BY restaurants.id
liefert in meiner Testumgebung auch nur 2 Restaurants, nicht alle drei
PS: Das ist meine Test-Datenbank (in ADS):
SQL-Code:
create table restaurants(id integer, name cichar(30));
create table gerichte(id integer, restaurant_id integer, name cichar(30));
create table bestellungen(id integer,gericht_id integer, datum date);

insert into restaurants values(1,'Löwen');
insert into restaurants values(2,'Ochsen');
insert into restaurants values(3,'Sonne');

insert into gerichte values(1,1,'Braten');
insert into gerichte values(2,1,'Schnitzel');
insert into gerichte values(3,2,'Eintopf');
insert into gerichte values(4,2,'Suvlaki');
insert into gerichte values(5,3,'Pommes');
insert into gerichte values(6,3,'Currywurst');

insert into bestellungen values(1,1,curdate());
insert into bestellungen values(2,2,curdate());
insert into bestellungen values(3,3,curdate());
Joachim Dürr
Joachim Dürr Softwareengineering
http://www.jd-engineering.de
  Mit Zitat antworten Zitat
jobo

Registriert seit: 29. Nov 2010
3.072 Beiträge
 
Delphi 2010 Enterprise
 
#12

AW: Datensatz immer ausgeben

  Alt 2. Dez 2010, 11:19
Wenn die Restaurants nicht extra ausgewertet werden (mit outer join), können die leeren auch nicht auftauchen. Dein erstes Beispiel war gut.
  Mit Zitat antworten Zitat
rokli

Registriert seit: 21. Mär 2009
Ort: Rödinghausen
301 Beiträge
 
Delphi 10.4 Sydney
 
#13

AW: Datensatz immer ausgeben

  Alt 2. Dez 2010, 12:10
Hi,

beim Microsoft SQL Server gibts den Befehl COALESCE

Abfrage 1:

SELECT smiGkLage FROM tblTest

Das Ergebnis siehst Du in Ergebnis1.JPG

Abfrage 2:

SELECT COALESCE(smiGkLage, -1) FROM tblTest

Das Ergebnis wird durch COALSECE so manipuliert, dass wenn das Ergebnis NULL ist, der 2. Wert in der Klammer eingesetzt wird. (siehe Ergebnis2.jpg)

Vielleicht gibst in Deiner DB auch so eine Möglichkeit

Gruß
Rolf
Miniaturansicht angehängter Grafiken
ergebnis1.jpg   ergebnis2.jpg  
Rolf
wenn nicht anders angegeben, schreibe ich zu D7, XE2 und MS SQL - ansonsten fragen Sie ihren Administrator oder einen Operator. Update 06/2020: Delphi 10.4 Sydney
  Mit Zitat antworten Zitat
jobo

Registriert seit: 29. Nov 2010
3.072 Beiträge
 
Delphi 2010 Enterprise
 
#14

AW: Datensatz immer ausgeben

  Alt 2. Dez 2010, 13:07
Coalesce ist manchmal nützlich, aber nicht, wenn man gar keinen Datensatz hat.
Die Anforderung war, "Datensatz immer ausgeben", nicht "Feld immer anzeigen".

Ein Datensatz wird immer ausgegeben, wenn alle where - Bedingungen passen, ob aus einem Join oder wie auch immer. Das Beispiel von Joachim zeigt das ja schon.
  Mit Zitat antworten Zitat
Tyrolean

Registriert seit: 3. Jul 2003
76 Beiträge
 
Delphi 7 Professional
 
#15

AW: Datensatz immer ausgeben

  Alt 2. Dez 2010, 14:36
So gehts bei mir nun auch

SQL-Code:
SELECT DISTINCT
  Sum(case when bestellungen.datum is null then 0 else 1 end) AS Anzahl,
  restaurants.id AS Id
FROM restaurants,gerichte
left outer join bestellungen on bestellungen.gericht_id = gerichte.id
WHERE
gerichte.restaurant_id = restaurants.id
AND (bestellungen.datum = CURRENT_DATE() OR bestellungen.datum is null)
GROUP BY restaurants.id
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 2 von 2     12   


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 15:28 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