zoukankan      html  css  js  c++  java
  • mysql编码详解

    在开发程序的时候,我们使用mysql数据库开发的时候,有时会碰到自己明明输入的是中文,为什么数据库中存储的就是????

    1、在配置Connection URL时,加上?useUnicode=true&characterEncoding=utf-8

    2、编辑/etc/my.cnf

    在[mysqld]下添加

    default-character-set=utf8

    在[client]下添加

    default-character-set=utf8

     

    可是这样做的原理是什么?为什么这样做就能解决问题那?

    逐步分析一下:

    1、useUnicode=true这个用加吗?答案是不用,翻看connector-j-en.a4.pdf

     

    它的默认值就是true

    2、 mysqld 下的default_character_set=utf8;,这个需要吗?答案是不需要。查看refman-5.1

    它的作用是

    当启动mysqld时,根据使用的初始选项设置来确定服务器字符集和 校对规则。可以使用--default-character-set设置字符集;

    如果在CREATE TABLE语句中没有指定表字符集和校对规则,则使用数据库字符集和校对规则作为默认值。默认数据库的字符集和校对规则可以用作character_set_database和 collation_database系统变量。无论何时默认数据库更改了,服务器都设置这两个变量的值。如果没有 默认数据库,这两个变量与相应的服务器级别的变量(character_set_server和collation_server)具有相同的值。

     

    大白话就是:如果你建表的时候没有指定字符编码,则会使用character_set_database,如果character_set_database也没有设值,则使用character_set_server

    3、 client 下的default_character_set=utf8; 它是需要的,可是它的作用是干吗的?

    它的作用等同执行以下3个命令

    SET character_set_client = utf8

    SET character_set_results = utf8;

    SET character_set_connection = utf8;

     

    这3个参数的作用如下

     

    系统变量character_set_client:用来指定解析客户端传递数据的编码

    系统变量character_set_connection:用来指定数据库内部处理时使用的编码

    系统变量character_set_results:用来指定数据返回给客户端的编码方式

     

    现在讲述一下?useUnicode=true&characterEncoding=utf-8中的characterEncoding

    它的作用就是指定character_set_client和character_set_connection的值,而在jdbc链接中使用characterSetResults=UTF-8,即可设置character_set_results的值

    但是如上所述,当你配置了client的default_character_set之后,characterEncodingcharacterSetResults这两个变量你设置与否都不重要了。

     

    结论如下:

    如果你只愿意配置服务器的话:

    在[client]下添加

    default-character-set=utf8即可

    如果你只愿意配置客户端的话:

    你可以使用jdbc:mysql://localhost:3306/test? characterEncoding=UTF-8&characterSetResults=UTF-8即可

     

    使用jdbc

    character_set_client - utf8

    character_set_connection - utf8

    character_set_database - utf8

    character_set_filesystem - binary

    character_set_results -

    character_set_server - utf8

    character_set_system - utf8

    character_sets_dir - /usr/share/mysql/charsets/

    使用mysql客户端

    character_set_client utf8

      

    character_set_connection utf8

     

    character_set_database utf8

      

    character_set_filesystem binary

     

    character_set_results utf8

      

    character_set_server utf8

      

    character_set_system utf8

      

    character_sets_dir /usr/share/mysql/charsets/

  • 相关阅读:
    开始我的博客
    POJ 1284:Primitive Roots(素数原根的个数)
    数据结构作业——图的存储及遍历(邻接矩阵、邻接表+DFS递归、非递归+BFS)
    NYOJ 85:有趣的数(打表,规律)
    NYOJ 12:喷水装置(二)(贪心,区间覆盖问题)
    HDU 2058:The sum problem(数学)
    HDU 1716:排列2(全排列)
    HDU 2048:神、上帝以及老天爷(错排公式,递推)
    NYOJ 6:喷水装置(一)(贪心)
    BZOJ 2002:Bounce 弹飞绵羊(分块)
  • 原文地址:https://www.cnblogs.com/beiyeren/p/3835412.html
Copyright © 2011-2022 走看看