mysql中文乱码完全解决方案

mysql中文乱码问题查找
  1. 查看当前数据库的编码格式
    mysql> show create database test;
    如果非Utf8,则修改数据库格式为utf-8:
    ALTER DATABASE test DEFAULT CHARACTER SET utf8 COLLATE utf8_general_ci;

  2. 查看表的编码格式
    show create table user;
    结果中有这样的输出:

    CREATE TABLE `user` (
    `sid` int(11) NOT NULL,
    `nick` varchar(36) NOT NULL,
    `password` varchar(64) DEFAULT NULL,
    `role` varchar(10) CHARACTER SET latin1 DEFAULT NULL,
    PRIMARY KEY (`sid`)
    ) ENGINE=InnoDB DEFAULT CHARSET=utf8

    关注结果中表的编码CHARSET=utf8,如果非Utf8,则修改表的编码格式为utf-8:
    ALTER TABLE user DEFAULT CHARACTER SET utf8 COLLATE utf8_general_ci;

  3. 关注结果中各列的编码,如果非utf8,改成utf-8,如上面输出中role列的编码格式就是latin1,而不是utf8,修改:
    alter table user modify role VARCHAR(10) CHARACTER SET utf8;
    #####重启数据库,一般情况到此基本上就可以解决了.
  4. 如果以上3种方式还不行,那么就考虑是否是数据库链接的问题,以JAVA为例,需要在数据库链接后加上编码方式,如:
    jdbc:mysql://localhost:3306/db?characterEncoding=UTF-8
你也可以在创建数据库和表的时候使用utf-8编码
  • 创建数据库使用Utf-8CREATE DATABASE db_name DEFAULT CHARACTER SET utf8 COLLATE utf8_general_ci;
  • 创建表使用utf-8

    CREATE TABLE `database_user`
    (`ID` varchar(40) NOT NULL default '',
    `UserID` varchar(40) NOT NULL default '',)
    ENGINE=InnoDB DEFAULT CHARSET=utf8;

(转自 https://wuwawuwa.cn

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值