AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken SQL-Ausdruck gibt zu wenige DS zurück
Thema durchsuchen
Ansicht
Themen-Optionen

SQL-Ausdruck gibt zu wenige DS zurück

Ein Thema von BlueStarHH · begonnen am 4. Mär 2017 · letzter Beitrag vom 5. Mär 2017
Antwort Antwort
Benutzerbild von himitsu
himitsu
Online

Registriert seit: 11. Okt 2003
Ort: Elbflorenz
44.547 Beiträge
 
Delphi 12 Athens
 
#1

AW: SQL-Ausdruck gibt zu wenige DS zurück

  Alt 4. Mär 2017, 21:42
PK = Primary Key?


Zitat:
und wenn es für NAME1 und NAME2
Wieso seh ich dafür keine Bedingung in dem SQL?

Da es 1 gibt, sagt das exists immer True und somit kommt natürlich auch kein 0.
Ein Therapeut entspricht 1024 Gigapeut.
  Mit Zitat antworten Zitat
BlueStarHH

Registriert seit: 28. Mär 2005
Ort: Hamburg
868 Beiträge
 
Delphi 11 Alexandria
 
#2

AW: SQL-Ausdruck gibt zu wenige DS zurück

  Alt 4. Mär 2017, 21:47
PK = Primary Key?
Ja

Zitat:
und wenn es für NAME1 und NAME2
Wieso seh ich dafür keine Bedingung in dem SQL?

Da es 1 gibt, sagt das exists immer True und somit kommt natürlich auch kein 0.
Gut Frage, nächste Frage. Die Namen kenne ich nicht und sollen auch nicht eingegrenzt werden.

Geändert von BlueStarHH ( 4. Mär 2017 um 21:54 Uhr)
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu
Online

Registriert seit: 11. Okt 2003
Ort: Elbflorenz
44.547 Beiträge
 
Delphi 12 Athens
 
#3

AW: SQL-Ausdruck gibt zu wenige DS zurück

  Alt 4. Mär 2017, 22:05
Die Namen kenne ich nicht und sollen auch nicht eingegrenzt werden.
Doch, sollen sie.

Diese Felder waren in deinem Beschreibngssatz, also gehören sie auch in die Abfrage rein.


Auch wenn das AS nicht unbedingt nötig ist, finde ich es eigentlich "verständlicher", wenn man es schreibt.

EXISTS(SELECT true FROM "alle" Felder aufzunehmen ist doch ein bissl sinnlos?

Und Statt != meinst du bestimmt = ?


Statt dem SubSelect könnte man bestimmt auch einen LEFT JOIN verwenden.
Ein Therapeut entspricht 1024 Gigapeut.

Geändert von himitsu ( 4. Mär 2017 um 22:09 Uhr)
  Mit Zitat antworten Zitat
nahpets
(Gast)

n/a Beiträge
 
#4

AW: SQL-Ausdruck gibt zu wenige DS zurück

  Alt 4. Mär 2017, 22:16
Werde Dein SQL mal etwas abkürzen unter der Voraussetzung, dass es mindestens einen Satz mit UserID 1 gibt.
SQL-Code:
select * from WERTE
where (UserID = 1)
or (UserID = 0 and not exists(True))
Also Du fragst quasi ab, ob es einen Satz mit der UserID 1 gibt oder einen Satz mit UserID = 0 und nicht "wahr"

Entspricht ungefähr:
Code:
or (1 = 1 and not true) -> or (1 = 1 and false) -> or (true and false)
Bitte formuliere nochmal deine Aufgabenstellung genau aus, sie ist im ersten Post noch etwas "unscharf". Dann teile sie erstmal in die beiden Teile auf, die (vermutlich) dahinter stecken.

Den zweiten Teil müsstest Du dann in den "not exists"-Teil einfügen können. Dabei ist aber wesentlich, dass in der Where-Bedingung des zweiten Teiles auf den ersten Teil über irgendeinen Schlüssel verwiesen wird. Ohne diesen Verweis ist die Wherebedingung (wie momentan) so "unscharf", dass sie immer erfüllt ist und nicht nur für den konkret abzufragenden Datensatz. Oder anders formuliert: Momentan ist die not-exists-Klausel so unscharf, dass man sie auch getrost weglassen könnte, ohne dass sich das Ergebnis verändert.
  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 15:47 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