MySQL 乱码解决方案

由于一真开发使用OracleSqlServer ,很少使用MySql,所以一直对MySql不是很了解,但却知道MySQL的乱码很出名,这几天使用Oracle突然感觉有点麻烦,要边过程的服务器,不爽,还是在自己机器上面爽!索性就试一下MySQL,感觉MySQL还挺好用的,随之而来的就是早已经预测到的乱码问题。花费了一晚上报的时间Google MySQL的筹码的解决方案。下面简单介绍一下,MySQL使用期间编码字符集之间的转化,因为有转化才出现的乱码。

首先我们使用net start mysql 命令启动MySQL服务,

登录MySQL [mysql –u root –p   输入密码]进入MySQL,打入如下命令:

show variables like character%; 执行会显示如下变量:

打入show variables like ‘collation%’; 会有如下显示:

 

上面显示的都是一些MySQL的系统变量。

服务器(server)的字符集和排序(collation)是被 character_set_server collation_server这两个系统变量的值決定

数据库的默认(default) 字符集(character set) 排序(collation) 是被 character_set_database collation_database这两个系统变量system variables的值決定

想想"连接connection"是什么:是你连到服务器Server时作的事情。客户端Client通过这条连接发送SQL语句(statements),比如查询(queries),通过 connectionserver, 服务器则送回回应,像是结果集合 result sets, 通过连接给客户端client,这导致了客户端连接client connections处理字符集和collation的一些问题。

下面来清楚几个问题?

1.当查询 离开客户端时 是什么字符集?

服务器读取character_set_client

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
对于 Liquibase 和 MySQL乱码问题,有几种可能的原因和解决方案。 1. 数据库字符集不匹配:请确保数据库的字符集和你的应用程序或 Liquibase 配置文件中指定的字符集一致。你可以通过执行以下命令来检查数据库的字符集: ```sql SHOW VARIABLES LIKE 'character_set_database'; ``` 如果数据库的字符集与应用程序或配置文件中指定的字符集不匹配,可以通过执行以下命令来修改数据库字符集: ```sql ALTER DATABASE your_database_name CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci; ``` 2. 数据库连接参数设置错误:在 Liquibase 配置文件中,确保你的数据库连接 URL 中包含正确的字符集参数。例如,在 MySQL 的连接 URL 中添加 `useUnicode=true&characterEncoding=utf8` 参数。 示例: ```xml <databaseChangeLog xmlns="http://www.liquibase.org/xml/ns/dbchangelog" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://www.liquibase.org/xml/ns/dbchangelog http://www.liquibase.org/xml/ns/dbchangelog/dbchangelog-3.8.xsd"> <changeSet id="example" author="your_name"> <createTable tableName="example_table"> <column name="example_column" type="VARCHAR(255)"/> </createTable> </changeSet> </databaseChangeLog> ``` 3. 数据库驱动版本问题:确保你使用的 MySQL 驱动程序版本与数据库服务器版本兼容。尝试使用最新的 MySQL 驱动程序,以确保获得最佳的兼容性和稳定性。 如果以上方法都没有解决你的问题,可以提供更多详细信息,例如具体的错误消息或代码片段,以便更好地帮助你解决乱码问题。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值