全國最多中醫師線上諮詢網站-台灣中醫網
發文 回覆 瀏覽次數:1446
推到 Plurk!
推到 Facebook!

MySQL 出現Incorrect string value致無法儲存

答題得分者是:GrandRURU
keny1024
一般會員


發表:6
回覆:8
積分:2
註冊:2010-03-19

發送簡訊給我
#1 引用回覆 回覆 發表時間:2020-06-08 16:45:26 IP:114.34.xxx.xxx 未訂閱
小弟使用Delphi XE 8以FireDAC連接MySQL資料庫,CharacterSet設為使用 FDTable"這個字,時發生了[FireDAC][Phys][MySQL] Incorrect string value:'\xF0\xA0\x99\xA6' for column 'MB_NAME' at row 1.的錯誤。上網爬文,在My.ini中設定
utf8mb4
[mysql] default-character-set=utf8mb4 collation-server='SET NAMES utf8mb4'
謝謝!
GrandRURU
站務副站長


發表:240
回覆:1680
積分:1874
註冊:2005-06-21

發送簡訊給我
#2 引用回覆 回覆 發表時間:2023-05-10 15:12:39 IP:59.120.xxx.xxx 未訂閱
根據您提供的錯誤信息,看起來是在嘗試插入或更新包含一些特殊字符的字符串時出現了問題。這通常是由於該字符集不支持這些字符或該字段的編碼方式不正確所引起的。
為了解決這個問題,您可以按照以下步驟來調整FireDAC和MySQL的設置:
  1. 打開My.ini文件,通常可以在MySQL安裝目錄下找到。
  2. 找到[mysql]段落,並將default-character-set設置為utf8mb4,如下所示:
    [mysql] default-character-set=utf8mb4
  3. 找到[mysqld]段落,並將character-set-server和collation-server設置為utf8mb4,如下所示:
    [mysqld] character-set-server=utf8mb4 collation-server=utf8mb4_unicode_ci
  4. 保存文件並重新啟動MySQL服務。
  5. 在Delphi中,使用以下代碼來設置FireDAC的CharacterSet屬性:
    FDConnection.Params.Values['CharacterSet'] := 'utf8mb4';
    或者,如果您正在使用FDTable,可以使用以下代碼:
    FDTable.Params.Values['CharacterSet'] := 'utf8mb4';
通過這些步驟,您應該能夠成功連接MySQL數據庫並使用utf8mb4字符集來處理特殊字符。
系統時間:2024-04-29 5:10:46
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!