Leggere i dati utilizzando ODBC ADO.NET da DB2 tabella codici 1252 - Euro (€) simbolo non è retrived correttamente
-
02-10-2019 - |
Domanda
In VS 2005 C #, mentre l'inserimento di Euro (€) Simbolo nella tabella DB2, E è la memorizzazione dei valori correctectly. DISABLEUNICODE = parametro 1 ha contribuito a conservare correttamente questo.
Ma quando proviamo a leggere dalla tabella, che sta dando char spazzatura come di seguito.
"Spec GS 1"
Lo stesso codice funziona in VB 6.0 ADO
La prego di aiuto.
Codice:
OdbcConnection con = new OdbcConnection();
OdbcDataAdapter dataAdapter = new OdbcDataAdapter("SELECT * FROM XXXX.XXXX" , con);
OdbcCommand odbcCommand =
new OdbcCommand(
"INSERT INTO XXXX.XXXX( BREACH_TYPE,JURISDICTION,ACTIVE ,VERIFIED , UPDATED_TS , UPDATED_BY ,VERIFIED_TS ,VERIFIED_BY)VALUES ('Spec GS € 1','IRE','Y','Y',CURRENT TIMESTAMP,'XECCRT3',CURRENT TIMESTAMP,'XECCRT8')");
con.ConnectionString = "DSN=DSNT;UID=xxxxxx;PWD=xxxxxx;MODE=SHARE;DBALIAS=DSNT;DISABLEUNICODE=1;PATCH1=1024;LONGDATACOMPAT=1;LOBMAXCOLUMNSIZE=1048575;PATCH2=6;";
con.Open();
odbcCommand.Connection = con;
odbcCommand.ExecuteNonQuery();
dataAdapter.SelectCommand.CommandTimeout = 0;
DataSet dataSet = new DataSet();
dataAdapter.Fill(dataSet);
DataTable result = dataSet.Tables[0];
string Text = result.Rows[0][0].ToString();
MessageBox.Show(Text = result.Rows[0][0].ToString());
con.Close();
Soluzione
Dopo la lettura del testo da DataSet, utilizzare la seguente funzione codificante per visualizzare dati corretti.
private static string ConvertToAsciiString(string str)
{
Encoding source = Encoding.Default ;
Encoding dest = Encoding.Unicode ;
// Convert the string into a byte[].
byte[] sourceBytes = dest.GetBytes(str);
// Perform the conversion from one encoding to the other.
byte[] destBytes = Encoding.Convert(source, dest, sourceBytes);
string asciiString = dest.GetString(destBytes);
asciiString = asciiString.Replace("\0", string.Empty);
return asciiString;
}
Autorizzato sotto: CC-BY-SA insieme a attribuzione
Non affiliato a StackOverflow