DbLog: Data too long for column 'VALUE' at row 1 at ./FHEM/93_DbLog.pm line 447.

Begonnen von vbs, 13 März 2015, 11:14:58

Vorheriges Thema - Nächstes Thema

vbs

Wenn ich Readings aus dem statistics-Modul in die DB loggen möchte, zB "Hour: 226.7 Day: 1520.0 Month: - Year: - (since: 2015-03-12_21:19:07 )", dann kommt die Meldung:

2015.03.13 10:59:54 2: DbLog: Failed to insert new readings into database: DBD::mysql::st execute failed: Data too long for column 'VALUE' at row 1 at ./FHEM/93_DbLog.pm line 447.


In der DB hat VALUE eine Länge von 32. Das kann ich jetzt natürlich größer machen in der DB, aber ist das der richtige Weg? Wie macht ihr das? Man könnte ja evtl. auch das Reading kürzen.

betateilchen

-----------------------
Formuliere die Aufgabe möglichst einfach und
setze die Lösung richtig um - dann wird es auch funktionieren.
-----------------------
Lesen gefährdet die Unwissenheit!

Markus M.

Ähnlich das hier:
DBD::mysql::st execute_array failed: Data too long for column 'VALUE' at row 1 [err was 1406 now 2000000000]
executing 1 generated 1 errors at /opt/fhem/FHEM/93_DbLog.pm line 1197.
, DBD::mysql::st execute_array failed: Data too long for column 'VALUE' at row 2682 [err was 1406 now 2000000000]
executing 1 generated 1 errors at /opt/fhem/FHEM/93_DbLog.pm line 1232.


Das Problem ist, dass einigermassen sinnvolles Logging bzw. Fehlerbehandlung an der Stelle fehlt.
Woher soll ich jetzt wissen wo das Problem liegt?
Aktuell weder Smarthome noch FHEM vorhanden

JoeALLb

Das aktuelle DbLog schneidet die Events ab, die länger sind als die Feldbreite in der Datenbank, also sollte ein Update schon helfen.
Ein berbreitern des Feldes in der DB funktioniert dadurch ebenfalls, die Standardbreite wurde auch auf 64 Zeichen erhöht.
Den Sinn oder Unsinn dahiner muss sich jeder selbst überlegen.

Wenn Du dann Logs suchst, die zu lange Values erzeugen, kannst Du immer nach dem Schema
lange Logeinträge suchen und die entsprechenden Devices dann nach Bedarf umkonfigurieren:

select * from history where length(value) > 30 limit 10;
(Das ist nur ein Schema, also ungetestet)


sG
Joe
FHEM-Server auf IntelAtom+Debian (8.1 Watt), KNX,
RasPi-2 Sonos-FHEM per FHEM2FHEM,RasPi-3 Versuchs-RasPi für WLAN-Tests
Gateways: DuoFern Stick, CUL866 PCA301, CUL HM, HMLan, JeeLink, LaCrosse,VCO2
Synology. Ardurino UNO für 1-Wire Tests, FB7270