Dapper操作MySQL数据库获取JSON数据时中文乱码怎么办

本篇内容介绍了“Dapper操作MySQL数据库获取JSON数据时中文乱码怎么办”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

创新互联成立与2013年,先为友谊等服务建站,友谊等地企业,进行企业商务咨询服务。为友谊企业网站制作PC+手机+微官网三网同步一站式服务解决您的所有建站问题。

在项目中利用Dapper将JSON数据存储到MySQL数据库,结果发现JSON数据中的中文乱码。

为了引出最终问题出在什么地方,我们重头开始进行讲解,首先我们给出如下测试实体以及在数据库中的表,如下:

Dapper操作MySQL数据库获取JSON数据时中文乱码怎么办

Dapper操作MySQL数据库获取JSON数据时中文乱码怎么办

为了数据操作方便,我们通过包【Dapper.SimpleCRUD】来操作,插入数据和查询数据如下:

Dapper操作MySQL数据库获取JSON数据时中文乱码怎么办

Dapper操作MySQL数据库获取JSON数据时中文乱码怎么办

Dapper操作MySQL数据库获取JSON数据时中文乱码怎么办

如上一切正常,接下来我们将存储JSON数据的列类型修改为json,然后再来进行如上操作,结果会发现获取数据中文将乱码:

Dapper操作MySQL数据库获取JSON数据时中文乱码怎么办

Dapper操作MySQL数据库获取JSON数据时中文乱码怎么办

刚开始我猜想难道用的包【Dapper.SimpleCRUD】在映射时出了问题,于是我用Dapper进行如下查询,依然会出现如上中文乱码:

Dapper操作MySQL数据库获取JSON数据时中文乱码怎么办

 所以由上基本可以得出结论:针对MySQL中的类型json,若json数据中存在中文,则利用Dapper查询时将出现乱码。那么如何解决这个问题呢?于是乎,在添加数据时,我将中文进行URL编码,再查询时进行解码即可,如下:

Dapper操作MySQL数据库获取JSON数据时中文乱码怎么办

Dapper操作MySQL数据库获取JSON数据时中文乱码怎么办

当然,上述解决方案以实际项目业务而去解决,我们项目需要获取到JSON数据中的中文然后通过URL传输,免去请求接口再去获取所存储的名称。到此我们了解了Dapper针对json数据类型将导致查询中文乱码的问题,但是其根本原因是什么呢?上述连接MySQL的驱动,是使用Oracle官方所提供的驱动且为最新版本,如下:

Dapper操作MySQL数据库获取JSON数据时中文乱码怎么办

我们知道通过EF Core操作MySQL数据库,若是利用官方包有一堆问题存在,所以大多都是采用的包【Pomelo.EntityFrameworkCore.MySql】,因为里面包含【MySqlConnector】,换句话说也就存在MySQL的驱动连接,所以这里我们尝试利用该包替换上述【MySql.Data】包,结果发现中文不再乱码。

Dapper操作MySQL数据库获取JSON数据时中文乱码怎么办

综上所述,我们需要注意的是若利用官方驱动包【MySql.Data】,当配置MySQL中的列类型为json时,若json数据中存在中文,则利用Dapper查询时将会出现中文乱码,需要进行转换。上述在数据库连接字符串中我们设置为utf8mb4,所以理论上应该和编码没有任何关系。

“Dapper操作MySQL数据库获取JSON数据时中文乱码怎么办”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注创新互联网站,小编将为大家输出更多高质量的实用文章!


网站名称:Dapper操作MySQL数据库获取JSON数据时中文乱码怎么办
链接URL:http://pwwzsj.com/article/gjdcge.html