mysql5插入亂碼問題 在數據庫由4.2升級到5.1.6-comm...之後 都是latin1的默認編碼, 以前的程序插入中文亂碼 ,以前的寫法:在source中加入charset=gb2312,然後在插入前執行set names gb2312即可; 在網上找了好多文章,除了上面的寫法外 ,就是直接更改數據庫的設置,但是這個數據庫是買的別人的產品 ,不能隨便亂動,只好在代碼上作文章, 折騰了好久之後 ,得出以下結論與大家共享, latin1即是iso8859-1, 所以在插入之前需要將內容轉換為iso8859-1, 如下: Encoding iso88591 = Encoding.GetEncoding("iso8859-1"); Encoding df = Encoding.Default; byte[] gb2312bytes = df.GetBytes(content); //byte[] asciiBytes = Encoding.Convert(df, iso88591, gb2312bytes); tring str = iso88591.GetString(gb2312bytes); 這樣轉換之後 ,source中不用加入charset參數 ,程序中也不需要先執行set names **, 即可正常插入