linux下mysql中文乱码(中文问号)解决办法


安装完的MySQL的默认字符集为 latin1 ,为了要将其字符集改为用户所需要的(比如utf8),就必须改其相关的配置文件;由于linux下MySQL的默认安装目录分布在不同的文件下;不像windows一样放在同一目录下,只需修改其中的my.ini文件,重起后就生效了;所以先来看看linux下MySQL的数据库文件、配置文件和命令文件分别在不同的目录 : 

1、数据库目录,其所创建的数据库文件都在该目录下 
  /var/lib/mysql/ 
2、配置文件 (mysql.server命令及配置文件所在地) 
  /usr/share/mysql 
3、相关命令(如mysql mysqladmin等) 
  /usr/bin 
4、启动脚本(如mysql启动命令) 
  /etc/rc.d/init.d/ 

查看默认字符集 
#mysql -u root - p 
#(输入密码) 

mysql> show variables like 'character_set%';

修改字符集 修改 /etc/my.cnf文件

  1.  
    #/etc/my.cnf
  2.  
     
  3.  
    [client]
  4.  
    default-character-set=utf8
  5.  
     
  6.  
    [mysqld]
  7.  
    datadir=/var/lib/mysql
  8.  
    socket=/var/lib/mysql/mysql.sock
  9.  
    user=mysql
  10.  
    # Disabling symbolic-links is recommended to prevent assorted security risks
  11.  
    symbolic-links=0
  12.  
    #default-character-set=utf8
  13.  
    character-set-server=utf8
    collation-server=utf8_general_ci
  14.  
    init_connect='SET NAMES utf8'
  15.  
     
  16.  
    [mysql]
  17.  
    no-auto-rehash
  18.  
    default-character-set=utf8
  19.  
     
  20.  
    [mysqld_safe]
  21.  
    log-error=/var/log/mysqld.log
  22.  
    pid-file=/var/run/mysqld/mysqld.pid
切记:在mysqld中加入的是 character-set-server=utf8 而不是 default-character-set=utf8 
否则会报:Starting MySQL...The server quit without updating PID file [失败]lib/mysql/localhost.localdomain.pid).异常

重起MySQL服务器,使其设置的内容生效 
  1.  
    一、启动方式
  2.  
    1、使用 service 启动:service mysqld start
  3.  
    2、使用 mysqld 脚本启动:/etc/inint.d/mysqld start
  4.  
    3、使用 safe_mysqld 启动:safe_mysqld&
  5.  
     
  6.  
    二、停止
  7.  
    1、使用 service 启动:service mysqld stop
  8.  
    2、使用 mysqld 脚本启动:/etc/inint.d/mysqld stop
  9.  
    3、 mysqladmin shutdown
  10.  
     
  11.  
    三、重启
  12.  
    1、 使用 service 启动:service mysqld restart
  13.  
    2、使用 mysqld 脚本启动:/etc/inint.d/mysqld restart


 


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM