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, 3516 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
Mit sql eine Zeile einfügen, select und feste Werte (9)

Frage von helmuthelmut2000 zum Thema Datenbanken ...

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
Sicherheit

How I hacked hundreds of companies through their helpdesk

Information von SeaStorm zum Thema Sicherheit ...

Erkennung und -Abwehr

Ccleaner-Angriff war nur auf große Unternehmen gemünzt

(10)

Information von Lochkartenstanzer zum Thema Erkennung und -Abwehr ...

Sicherheit

Eventuell neue Lücke in Intels ME

Information von sabines zum Thema Sicherheit ...

Heiß diskutierte Inhalte
Humor (lol)
Freidach Beitrag (35)

Frage von Penny.Cilin zum Thema Humor (lol) ...

Windows 7
SSD - Win7 Lags (19)

Frage von ph5555 zum Thema Windows 7 ...