So, ich stehe vor einem gravierenden Problem!
Irgendwann hat mal ein Urentwickler, ne Idee gehabt, man könnte doch Werte (die sowieso immer nur von 0-255) als byte array in der Datenbank abspeichern!
Tjo, soweit auch net schlimm. Problem ist jetzt aber jenes, das ich mit der MS SQL DB bei den Werten 129 und 140 - 144 immer 63 zurückkriege! (wahrscheinlich sinds noch mehr, aber die habe ich mal rausgefunden).
Egal ob ich mit getBytes(), getString, getAsciiStream, getCharacterStream oder getObject zurückhole!
Es ist immer wenn ich mitdebugge sofort 63 oder 65533. Ich kriege einfach NIE den richtigen Wert der in der DB steht!
Lasse ich mir mit einem C-Tool den Inhalt ausgeben, so wird dieser richtig angezeigt!
Hex Code 81 für 129, etc.. Also in der DB stehts richtig und das lustige ist, dass sogar das gleiche Programm die Werte richtig in die DB schreibt! Aber zu unfähig ist, diese Werte auch wieder rauszulesen.
Da es ja nirgends (oder gibt es eine?) Möglichkeit gibt, den Charset für Java allg. oder für die Datenbankverbindung festzulegen, drehe ich schön langsam bald durch.
Dann habe ich heute die Methode getBinaryStream probiert und sie hat funktioniert! Via ODBC Bridge auf eine JET DB (dort war das gleiche Phänomen, warum auch immer - unter Oracle hingegen tritt dieses Problem NIE auf - mit dem gleichen Programm).
So, nun die getBinaryStream Methode am MS SQL Server angewandt mit den MS Treibern und es kommt ne Exception, dass der Treiber das nicht unterstütz!
Dann den jtds Treiber für MS SQL ausprobiert und dort kommt sowieso dann bei jedem Zeichen gößer 127 der Wert 63 zurück!
Weiß jemand Abhilfe? Kann man wo generell irgendwas festlegen welchen Charset, etc das Teil haben soll oder sonstiges?!?
Ich bin echt am verzweifeln, da ich eigentlich genug andere Arbeit zu tun hätte...
Irgendwann hat mal ein Urentwickler, ne Idee gehabt, man könnte doch Werte (die sowieso immer nur von 0-255) als byte array in der Datenbank abspeichern!
Tjo, soweit auch net schlimm. Problem ist jetzt aber jenes, das ich mit der MS SQL DB bei den Werten 129 und 140 - 144 immer 63 zurückkriege! (wahrscheinlich sinds noch mehr, aber die habe ich mal rausgefunden).
Egal ob ich mit getBytes(), getString, getAsciiStream, getCharacterStream oder getObject zurückhole!
Es ist immer wenn ich mitdebugge sofort 63 oder 65533. Ich kriege einfach NIE den richtigen Wert der in der DB steht!
Lasse ich mir mit einem C-Tool den Inhalt ausgeben, so wird dieser richtig angezeigt!
Hex Code 81 für 129, etc.. Also in der DB stehts richtig und das lustige ist, dass sogar das gleiche Programm die Werte richtig in die DB schreibt! Aber zu unfähig ist, diese Werte auch wieder rauszulesen.
Da es ja nirgends (oder gibt es eine?) Möglichkeit gibt, den Charset für Java allg. oder für die Datenbankverbindung festzulegen, drehe ich schön langsam bald durch.
Dann habe ich heute die Methode getBinaryStream probiert und sie hat funktioniert! Via ODBC Bridge auf eine JET DB (dort war das gleiche Phänomen, warum auch immer - unter Oracle hingegen tritt dieses Problem NIE auf - mit dem gleichen Programm).
So, nun die getBinaryStream Methode am MS SQL Server angewandt mit den MS Treibern und es kommt ne Exception, dass der Treiber das nicht unterstütz!
Dann den jtds Treiber für MS SQL ausprobiert und dort kommt sowieso dann bei jedem Zeichen gößer 127 der Wert 63 zurück!
Weiß jemand Abhilfe? Kann man wo generell irgendwas festlegen welchen Charset, etc das Teil haben soll oder sonstiges?!?
Ich bin echt am verzweifeln, da ich eigentlich genug andere Arbeit zu tun hätte...