zoukankan      html  css  js  c++  java
  • 日志的乱码,以及数据库编码问题

        今天被一个小问题坑了一下下,没解决之前总是会有些情绪的,做其他事情时也总会一直回想,利用午休时间,终于把问题解决了,在这里做个总结,避免以后遇到类似问题不知所措,同时也给遇到相同问题的朋友一个小帮助....

        问题的起因是这样的,在开发过程中,我使用了mybatis 对mysql数据库进行读写,传入后台的参数中有中文,一开始的问题是,控制台输出乱码,找了相关资料,设置了IDEA的环境,还是没有效果,后来才发现问题出在日志的配置文件上,原先的写法是:

    后来添加了一行,如下图:

         控制台能正常的输出中文了,到此,我以为问题已经解决,可以后来执行sql语句查询数据库时,每次的返回结果都是0,起初我的怀疑是sql语句出了问题,于是将sql语句打印出来,在navicat上执行,结果是有数据的;后来我想会不会是mybatis代码生成插件的问题,但是之前另一个模块的代码也是使用同一框架,中文传参是可以查询出结果的,所以又排除了这个可能性;最后,我把关注的焦点放在了mysql上,sql语句没有报错,说明不是语句本身的问题,也许是参数的问题,查看了之前做过的一些模块的代码和配置文件,我发现了一些蛛丝马迹,又结合了日志打印的结果,最后把问题锁定在了数据库的连接上,项目中有个配置文件为jdbc.properties,内容如下:

    jdbc.url=jdbc:mysql://133.95.191.83:3306/om
    jdbc.username=admin
    jdbc.password=12345678
    jdbc.maxActive=35
    jdbc.maxIdle=10

    url中少了指定字符的编码,解码格式,因为mysql数据库是使用GBK编码,而我项目数据库中是使用UTF-8编码,这才是问题的原因所在,最后修改jdbc.url为
    jdbc.url=jdbc:mysql://133.95.191.83:3306/om?useUnicode=true&characterEncoding=utf8   

           问题解决了!  在开发的过程中我们总会遇到这样那样的问题,或小或大,每一次解决问题的过程,实际上都是很珍贵的经验与财富,编码如此,成长亦是如此。

    
    
  • 相关阅读:
    阿里P7架构师是如何解决跨域问题的!你有遇到吗?
    Node.js Express 框架
    用户管理 之 Linux 系统中的超级权限的控制
    [转] Exchange 2013 安装部署详解
    Clustered和Nonclustered Indexes 各自得特点和区别及长短处
    配置IIS5.5/6.0 支持 Silverlight
    redis模块使用
    redis介绍及安装
    linux上安装redis、远程配置及开机启动
    远程连接linux、配置SSHD
  • 原文地址:https://www.cnblogs.com/wuyunxing/p/4723963.html
Copyright © 2011-2022 走看看