Flex asSql庫在串連MySql時顯示中文字串為亂碼的問題

來源:互聯網
上載者:User

(assql是Flex用於串連MySql的一個開源庫,可以從http://code.google.com/p/assql/downloads/list下載到。)

問題:

通過使用assql查詢、更新、插入mysql記錄時,中文字元都呈現亂碼。

網上資訊:

通過百度、Google一堆解決辦法,基本上都是在修改assql原始碼,但最新的2.8版本都已經修複,所以改原始碼沒用。

問題根源:

不在於assql,而在於mysql的字元集設定。

mysql字元集的問題可以參看:http://apps.hi.baidu.com/share/detail/22337180

簡言之,就是將mysql上的字元集全都改為utf8,包括表中包含中文字元的每一列的字元集都改為utf8(如果是其它字元集,跟下面三個變數不一致,還是會出問題的)。

其中跟Flex關係最大的是下面3個變數:

character_set_client

character_set_connection

character_set_results    

因為flex跟mysql通訊實際上是用戶端跟伺服器之間的通訊,這樣的話伺服器在收到用戶端的請求時,要知道請求過來的字串是何種編碼,這是通過character_set_client知道的,然後mysql要把這種編碼的字串轉化為自身能解釋的字串,解釋成什麼字串就由character_set_connection決定,最後當需要向用戶端返迴響應時,Mysql還要知道該以何種編碼返回給用戶端,這又由character_set_results決定。

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.