Top-Themen

Aktuelle Themen (A bis Z)

Administrator.de FeedbackApache ServerAppleAssemblerAudioAusbildungAuslandBackupBasicBatch & ShellBenchmarksBibliotheken & ToolkitsBlogsCloud-DiensteClusterCMSCPU, RAM, MainboardsCSSC und C++DatenbankenDatenschutzDebianDigitiales FernsehenDNSDrucker und ScannerDSL, VDSLE-BooksE-BusinessE-MailEntwicklungErkennung und -AbwehrExchange ServerFestplatten, SSD, RaidFirewallFlatratesGoogle AndroidGrafikGrafikkarten & MonitoreGroupwareHardwareHosting & HousingHTMLHumor (lol)Hyper-VIconsIDE & EditorenInformationsdiensteInstallationInstant MessagingInternetInternet DomäneniOSISDN & AnaloganschlüsseiTunesJavaJavaScriptKiXtartKVMLAN, WAN, WirelessLinuxLinux DesktopLinux NetzwerkLinux ToolsLinux UserverwaltungLizenzierungMac OS XMicrosoftMicrosoft OfficeMikroTik RouterOSMonitoringMultimediaMultimedia & ZubehörNetzwerkeNetzwerkgrundlagenNetzwerkmanagementNetzwerkprotokolleNotebook & ZubehörNovell NetwareOff TopicOpenOffice, LibreOfficeOutlook & MailPapierkorbPascal und DelphiPeripheriegerätePerlPHPPythonRechtliche FragenRedHat, CentOS, FedoraRouter & RoutingSambaSAN, NAS, DASSchriftartenSchulung & TrainingSEOServerServer-HardwareSicherheitSicherheits-ToolsSicherheitsgrundlagenSolarisSonstige SystemeSoziale NetzwerkeSpeicherkartenStudentenjobs & PraktikumSuche ProjektpartnerSuseSwitche und HubsTipps & TricksTK-Netze & GeräteUbuntuUMTS, EDGE & GPRSUtilitiesVB for ApplicationsVerschlüsselung & ZertifikateVideo & StreamingViren und TrojanerVirtualisierungVisual StudioVmwareVoice over IPWebbrowserWebentwicklungWeiterbildungWindows 7Windows 8Windows 10Windows InstallationWindows MobileWindows NetzwerkWindows ServerWindows SystemdateienWindows ToolsWindows UpdateWindows UserverwaltungWindows VistaWindows XPXenserverXMLZusammenarbeit

gelöst SQL auf AS400 if-Abfrage in WHERE?

Mitglied: leanderchen

leanderchen (Level 1) - Jetzt verbinden

13.12.2006, aktualisiert 14.12.2006, 13071 Aufrufe, 7 Kommentare

Hallo zusammen,
ich habe ein Problem mit einem SQL-Statement, per iSeries Navigator auf einer AS400 abgesetzt, und zwar brauche ich sinngemäß eine if-Abfrage im WHERE-Teil.

Das Problem ist folgendes: Es sollen nur Datensätze gefunden werden, die in DATAUSMTG entweder 0 stehen haben oder ein Datum, das größer ist als das heutige Datum.

Nachdem ich nun schon eine Weile verzweifelt gegoogelt und einige Foren durchforscht habe, hoffe ich, hier kann mir jemand helfen.

Mein WHERE-Teil sieht zur Zeit (gekürzt auf die relevante Stelle) so aus:

WHERE (DATAUSMTG = 0 OR ((DATAUSMTG <> 0) AND DATE(substr(Digits(DATAUSMTG), 7, 2) || '.' || Substr(digits(DATAUSMTG),5,2) || '.' || Substr(digits(DATAUSMTG), 1, 4)) > date(now()))))

Solange in DATAUSMTG ein Datum steht, funktioniert das bestens. Steht dort aber 0, fällt das OR auf die Nase. Klar, da aus 0 kein Datum gebaut werden kann.

Ich dachte eigentlich, dass durch die Klammersetzung der hintere Teil des OR einfach ignoriert wird, aber dem ist wohl nicht so.

Hat jemand eine Idee?

Danke schon mal und Gruß
Jutta
Mitglied: Biber
13.12.2006 um 17:13 Uhr
Nachfrage, leanderchen,

Du bist Dir sicher, dass DATAUSMTG tatsächlich ein numerisches Feld und kein CHAR-Feld?
Und dort tatsächlich (numerisch) 0 steht und nicht NULL?

Grüße
Biber
Bitte warten ..
Mitglied: leanderchen
13.12.2006 um 17:35 Uhr
Hallo Biber,

ob das ein CHAR-Feld ist, kann ich leider nicht prüfen, da ich ja nur lesend auf die AS400 zugreifen kann.

NULL steht dort m. E. nie drin, da die Abfrage bisher (nur mit WHERE DATAUSMTG = 0, was bis heute morgen auch ausreichend war) immer gut funktioniert hat.

Seit heute weiß ich allerdings, dass auch Datensätze angezeigt werden sollen, bei denen DATAUSMTG anstelle der 0 ein Datum größer als das heutige Datum enthält.

Ich habe in der Zwischenzeit auch schon versucht, beides in einen String umzuwandeln, um die dann zu vergleichen, aber ich kann weder now() noch date(now()) in einen String umwandeln
Bitte warten ..
Mitglied: Biber
13.12.2006 um 19:17 Uhr
Hm,
nicht, dass ich verstehen würde, was da schräg läuft, aber umformen könnten wir es...
01.
...
02.
WHERE ( DATAUSMTG = 0
03.
OR 
04.
DATAUSMTG > Int(replace(char(date(now()), ISO),'-','')) )  
Date(now(), ISO) bzw. bei mir Date(current date, ISO) liefert das Datum im Format 2006-12-14.
char(davon)-----> '2006-12-14' (Char)
replace(char(davon),"-", "" ) -------->'20061214' (Char)
int(replace(char(davon),"-","")) --------> 20061214 (integer)

HTH
Biber
Bitte warten ..
Mitglied: leanderchen
14.12.2006 um 08:19 Uhr
Hallo Biber,

erst mal Danke für Deine Hilfe!

Aber der Spaß geht weiter, denn die AS400 kennt replace nicht. Oder zumindest kommt im Navigator die Meldung "REPLACE der Art *N in *LIBL wurde nicht gefunden."

Hast Du noch eine Idee, wie man den Wert aus DATAUSMTG in ein Datum umformen kann? Denn vielleicht geht es ja doch irgendwie in dieser Richtung. Obwohl ich das ja auch schon versucht hatte und die AS400 die Fehlermeldung brachte, dass man weder now() noch date(now()) per < oder > vergleichen könnte...
Bitte warten ..
Mitglied: leanderchen
14.12.2006 um 09:12 Uhr
Hallo Biber,

ich habe die Lösung inzwischen gefunden. Warum einfach, wenn es auch kompliziert geht???

So geht es:
<p>
WHERE (
DATAUSMTG = 0 OR
DATAUSMTG > int(substr(char(date(now())), 1, 4) ||
substr(char(date(now())), 6, 2) ||
substr(char(date(now())), 9, 2))
)
</p>
Trotzdem noch einmal vielen Dank für Deine Hilfe. Schließlich hast Du mir geholfen, das Brett vor meinem Kopf zu entfernen

Gruß
Jutta
Bitte warten ..
Mitglied: Biber
14.12.2006 um 09:28 Uhr
sorry, leanderchen,

so genau hab ich den Umfang der Skalar-Funktionen der AS400 nicht im Kopf.
Wusste nicht, dass REPLACE() nicht dabei ist...

Also bitte auch die folgende Alternative erstmal nur als Skizze nehmen:
01.
...WHERE ( 
02.
DATAUSMTG = 0
03.
OR 
04.
DATAUSMTG > Int(Substr(char(date(now()), ISO),'-',''), 1, 4) ||
05.
                Substr(char(date(now()), ISO),'-',''), 6, 2) ||
06.
                Substr(char(date(now()), ISO),'-',''), 9, 2))
07.
 )  
Falls die AS400 auch den Parameter "ISO" bei der DATE()-Function nicht kennt, dann bitte den Wert der Function Date(now()) so nehmen wie er ist und -sollte er im EUR-Format kommen, die Substr()-Arie von Konvertiere-YYYY-MM-DD-nach-Integer auf Konvertiere-TT.MM.JJJJ-nach-Integer umdrehen.

Ich würde aber auf jeden Fall den (gültigen) Date(now())-Wert nach Integer konvertieren statt zu versuchen, den ungeprüften DATAUSMTG-Wert in ein Datum umzuwandeln.

HTH
Biber

[Edit]
Da haben wir über Kreuz getippt--- vergiss es einfach
[/Edit]
Bitte warten ..
Mitglied: leanderchen
14.12.2006 um 12:58 Uhr
Nachtrag!

Da auch noch ein Unterschied besteht zwischen einem Zugriff auf AS400 per iSeries Navigator und dem Zugriff per ODBC und einem Java-Programm (und da, wie ich inzwischen weiß, DATAUSMTG ein decimal(8) ist), muss noch etwas geändert werden:

WHERE ((DATAUSMTG = 0) OR
(cast(DATAUSMTG as varchar(8)) > (substr(char(date(now())), 1, 4) || substr(char(date(now())), 6, 2) || substr(char(date(now())), 9, 2))))

Gruß
Jutta
Bitte warten ..
Ähnliche Inhalte
Server-Hardware
AS400 Drucker
Frage von rocco61Server-Hardware14 Kommentare

Hallo zusammen, wer kennt denn IBM AS 400 von euch? Haben seit paar Tagen das Problem, das der Druck ...

Datenbanken
IF Abfrage im SELECT Oracle SQL
gelöst Frage von 94451Datenbanken2 Kommentare

Hallo , ist es möglich im SELECT eine IF-Abfrage machen (bin auch offen für eine andere Lösung). >SELECT ID, ...

Batch & Shell

Powershell if() Abfrage bei SQL Stored Procedure execute Fehler?

gelöst Frage von FISIStewBatch & Shell13 Kommentare

Hallo zusammen, ich bräuchte Eure Hilfe, Das unten stehende Script ist nur ein Ausschnitt und Funktioniert! Allerdings möchte ich ...

Batch & Shell

Cmd If ()else(if) geht nicht

gelöst Frage von SaschaaaaaBatch & Shell2 Kommentare

Hallo Leute, ich habe mir ein kleines Script erstellt welches den PC herunterfährt wenn er 90 Minuten im Leerlauf ...

Neue Wissensbeiträge
Exchange Server

1und1 IONOS: Probleme beim Mailversand mit Exchange

Information von reksierp vor 4 StundenExchange Server3 Kommentare

Hallo, seit Do, 17.1.19 etwa Mittags nimmt 1und1 IONOS keine Mails mehr über den Standard-Port SMTP 25 an. Nachdem ...

LAN, WAN, Wireless

Cisco Mikrotik VPN Standort Vernetzung mit dynamischem Routing

Anleitung von aqui vor 17 StundenLAN, WAN, Wireless

1. Allgemeine Einleitung Das nachfolgende Tutorial ist eine Fortführung der hier bei Administrator.de schon bestehenden VPN Tutorials und beschreibt ...

Windows Mobile

Support für Windows Mobile endet im Dezember 2019

Information von transocean vor 2 TagenWindows Mobile

Moin, Microsoft empfiehlt als Alternative den Umstieg auf iOS oder Android, wie man hier lesen kann. Gruß Uwe

Internet

Kommentar: Bundesregierung erwägt Ausschluss von Huawei im 5G-Netz - Unsere Presse wird immer sensationsgieriger

Information von Frank vor 4 TagenInternet6 Kommentare

Hier mal wieder ein schönes Beispiel für fehlgeleiteten Journalismus und Politik zugleich. Da werden aus Gerüchten plötzlich Fakten, da ...

Heiß diskutierte Inhalte
LAN, WAN, Wireless
Temporäre WLAN Verbindung für AD-Login
Frage von Christian.WidauerLAN, WAN, Wireless17 Kommentare

Hallo zusammen, ich weiß leider nicht unter welchem Begriff ich dafür suchen muss, daher habe ich bisher leider nichts ...

LAN, WAN, Wireless
Bekannte Drosselungen bei Providern ?
Frage von HenereLAN, WAN, Wireless15 Kommentare

Servus zusammen, in bereits angefangen, aber ich hoffe dass der Beitrag hier mehr Informationen bringt. Sind Portdrosselungen bzw gezielte ...

Netzwerkmanagement
Reverse Proxy für TCP und UDP Anfragen
gelöst Frage von flxklsNetzwerkmanagement14 Kommentare

Hallo zusammen, ich besitze einen Rootserver, der nur eine öffentliche IP besitzt und auf dem mehrere VMs laufen. Da ...

Windows Server
MSSQL Backup in Form von .sql einspielen
Frage von janosch12Windows Server14 Kommentare

Guten Morgen, wir verwenden das Tool SQLandFTPBackup ( ) zum sichern einiger MSSQL Datenbanken. Nun sichert das Toll die ...