Top-Themen

AppleEntwicklungHardwareInternetLinuxMicrosoftMultimediaNetzwerkeOff TopicSicherheitSonstige SystemeVirtualisierungWeiterbildungZusammenarbeit

Aktuelle Themen

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

SQL Update: Berechnen aus 2 Zeilen!

Frage Entwicklung Datenbanken

Mitglied: Much2k

Much2k (Level 1) - Jetzt verbinden

17.02.2014 um 15:51 Uhr, 3434 Aufrufe, 1 Kommentar

Hallo!

Habe ein Problem wo ich keine Lösung finde. Kann man ein Script erstellen wo folgende Brechnung ausgeführt wird un d als Update in der Datenbank gespeichert wird?

Folgenden Aufbau Besitzt die Datenbank:

ID DateTime wh.pos WH_ver
1 2014-02-17 00:00:01 1250 NULL
2 2014-02-17 01:00:10 1300 NULL
3 2014-02-17 02:00:06 1750 NULL


Nun möchte ich ein Script ausführen, das den Leistungsverbracuh brechnet und als Update in DB einfügt. Alle Tests sind derzeit Fehlgeschlagen. Vileicht habt ihr einen Lösungsansatz?

Folgende Test ist auch fehlgeschlagen, funktioniert zwar als Select aber nicht als Update.

SELECT SET `WH_ver` =
a.wh_pos-(
select max(wh_pos) from dieseldaten_stunden where wh_pos < a.wh_pos) as Differenz_WH

Vielen Dank

Mfg
Michael
Mitglied: Biber
17.02.2014, aktualisiert um 18:43 Uhr
Moin Much2k,

es geht ja, wenn ich das verstümmelte Statement richtig deute, nur um EINE Tabelle namens dieseldaten_stunden.

Wenn ja, dann muss das SELECT-Statement so (oder ähnlich) lauten.
01.
SELECT a.id, a.DateTime, a.wh_pos  
02.
a.wh_pos-( 
03.
 select max(wh_pos) from dieseldaten_stunden where wh_pos < a.wh_pos)  
04.
as Differenz_WH  
05.
from dieseldaten_stunden
Aber bevor du das als UPDATE.Statement umschreibst, muss es erstmal sauber funktionieren - und das macht es IMHO nicht.
Denn in den Fällen, in denen im Inline-Select " ..Max(wh_pos) WHERE wh_pos < a.wh_pos) " gar keine kleinere wh_pos gefunden wird, also z.B. bei der ID 1, --> wir die Formel aufgelöst zu ergibt das errechnete Feld "wh_pos - (NULL)".

Okay, ein numerischer Wert minus NULL ergibt bei (fast) allen DBMSen keinen Fehler, sondern wieder NULL... aber
a) ist das nur ein Entgegenkommen des Datenbank-Designers, nichts Einklagbares
b) warum solltest du ein Feld mit dem jetzigen Inhalt NULL mit dem Wert NULL updaten wollen? Weil du es kannst...?

Wenn du das alles billigend in Kauf nimmst, dann wäre das Updatestatement (das ALLE Datensätze unabhängig von einer Notwendigkeit) updated:
01.
UPDATE dieseldaten_stunden a 
02.
SET WH_ver = 
03.
a.wh_pos-( 
04.
   select max(wh_pos) from dieseldaten_stunden  
05.
    where wh_pos < a.wh_pos)  
06.
;
Wenn du im oben beschriebenen "überschreibe NULL mit NULL"-Fall eher einen Wert 0 statt NULL schreiben willst:
-> dann musst du das Inline-Select mit NVL( (select max()... from bla), 0) aufhybschen
[Edit:NVL( prüfwert, FallsNULLErsatzwert) heisst es bei Oracle, bei dir ist es vermutlich mySQL-
-> dann stattdessen IfNull( prüfwert, FallsNULLErsatzwert) .// mySQL-Äquivalent
Oder auch Coalesce( prüfwert, FallsNULLErsatzwert) , das können (fast) alle, also mindestens Oracle, DB2, mySQL. [/Edit]


Wenn du die Ersetze-NULL-durch-NULL-Werte gar nicht erst schreiben willst
-> dann musst du eine entsprechende WHERE-Clause anfügen.

Grüße
Biber
Bitte warten ..
Ähnliche Inhalte
Entwicklung
gelöst SQL Update aus derselben Tabelle (1)

Frage von winscheil zum Thema Entwicklung ...

Datenbanken
MS SQL - Update Text Feld mit Steuerzeichen (4)

Frage von emeriks zum Thema Datenbanken ...

Windows Server
gelöst Update BackupExec 2015 auf 2016 führt zu SQL-Server Problem (19)

Frage von montylein1981 zum Thema Windows Server ...

Windows Server
gelöst SQL Server 2008R2 Update über Windows Microsoft Updates wird nicht mehr angeboten (4)

Frage von TimSterntaler zum Thema Windows Server ...

Neue Wissensbeiträge
Administrator.de Feedback

Umgangsformen auf der Seite

(7)

Information von Frank zum Thema Administrator.de Feedback ...

Windows 10

Windows 8.x oder 10 Lizenz-Key aus dem ROM auslesen mit Linux

(10)

Tipp von Lochkartenstanzer zum Thema Windows 10 ...

Heiß diskutierte Inhalte
Batch & Shell
gelöst Dir tc Befehl unter Windows 10 macht Probleme (14)

Frage von sugram zum Thema Batch & Shell ...

Windows Server
Windows Server 2016 RDS Remoteapp Anzeigefehler (11)

Frage von qlnGenius zum Thema Windows Server ...

Windows Server
Festplatten Ruhezustand Windows Server 2016 (10)

Frage von ahaeuser zum Thema Windows Server ...