Top-Themen

AppleEntwicklungHardwareInternetLinuxMicrosoftMultimediaNetzwerkeOff TopicSicherheitSonstige SystemeVirtualisierungWeiterbildungZusammenarbeit

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

SQL Update: Berechnen aus 2 Zeilen!

Frage Entwicklung Datenbanken

Mitglied: Much2k

Much2k (Level 1) - Jetzt verbinden

17.02.2014 um 15:51 Uhr, 3550 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
Access 2010 Entwicklung berechnen (1)

Frage von Dr.Cornwallis zum Thema Datenbanken ...

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
Multimedia

Raspberry Pi als Digital-Signage-Computer

(1)

Information von BassFishFox zum Thema Multimedia ...

Windows Update

Novemberpatches und Nadeldrucker bereiten Kopfschmerzen

(15)

Tipp von MettGurke zum Thema Windows Update ...

Windows 10

Abhilfe für Abstürze von CDPUsersvc auf Win10 1607 und 2016 1607

(7)

Tipp von DerWoWusste zum Thema Windows 10 ...

Heiß diskutierte Inhalte
Router & Routing
Freigabe aus anderem Netz nicht erreichbar (21)

Frage von McLion zum Thema Router & Routing ...

Windows Server
Kennwort vergessen bei Hyper vserver 2012r (20)

Frage von jensgebken zum Thema Windows Server ...

Batch & Shell
Batch Programm verhalten bei shoutdown -p (19)

Frage von Michael-ITler zum Thema Batch & Shell ...

Festplatten, SSD, Raid
gelöst Raidcontroller funktioniert nur, wenn unter Legacy-Boot gestartet wird (14)

Frage von DerWoWusste zum Thema Festplatten, SSD, Raid ...