• 首页
  • vue
  • TypeScript
  • JavaScript
  • scss
  • css3
  • html5
  • php
  • MySQL
  • redis
  • jQuery
  • 字符集配置

    MySQL服务器具有内置的默认字符集和校验规则。要更改这些默认值,请在启动服务器时使用--character-set-server--collation-server选项。请参见“服务器命令选项”。该校验规则必须是默认字符集的合法校验规则。若要确定每个字符集可用的校验规则,请使用SHOW COLLATION语句或查询INFORMATION_SCHEMACOLLATIONS表。

    如果您尝试使用未编译到二进制文件中的字符集,则可能会遇到以下问题:

    • 如果您的程序使用错误的路径来确定字符集的存储位置(通常是MySQL安装目录下的share/mysql/charsetsshare/charsets目录),则可以--character-sets-dir在运行程序时通过使用选项来解决此问题。例如,要指定MySQL客户端程序要使用的目录[client],请在选项文件的组中列出该目录。此处给出的示例分别显示了Unix或Windows的设置:

      [client]
      character-sets-dir=/usr/local/mysql/share/mysql/charsets
      
      [client]
      character-sets-dir="C:/Program Files/MySQL/MySQL Server 8.0/share/charsets"
      
    • 如果字符集是无法动态加载的复杂字符集,则必须在支持该字符集的情况下重新编译程序。

      对于Unicode字符集,您可以使用LDML表示法定义校验规则,而无需重新编译。请参见“将UCA检验添加到Unicode字符集”。

    • 如果字符集是动态字符集,但是您没有针对它的配置文件,则应该从新的MySQL发行版中安装字符集的配置文件。
    • 如果您的字符集索引文件(Index.xml)不包含该字符集的名称,则程序将显示错误消息:

      Character set 'charset_name' is not a compiled character set and is not
      specified in the '/usr/share/mysql/charsets/Index.xml' file
      

      要解决此问题,您应该获取一个新的索引文件,或者将所有缺少的字符集的名称手动添加到当前文件中。

    您可以强制客户端程序使用特定的字符集,如下所示:

    [client]
    default-character-set=charset_name
    

    通常这是不必要的。但是,当character_set_system不同于character_set_server或时character_set_client,并且您手动输入字符(作为数据库对象标识符,列值或两者)时,这些字符可能在客户端的输出中显示不正确,或者输出本身的格式不正确。在这种情况下,以以下方式启动mysql客户端(即,将客户端字符集设置为与系统字符集匹配)应该可以解决该问题。--default-character-set=system_character_set