本网站(662p.com)打包出售,且带程序代码数据,662p.com域名,程序内核采用TP框架开发,需要联系扣扣:2360248666 /wx:lianweikj
精品域名一口价出售:1y1m.com(350元) ,6b7b.com(400元) , 5k5j.com(380元) , yayj.com(1800元), jiongzhun.com(1000元) , niuzen.com(2800元) , zennei.com(5000元)
需要联系扣扣:2360248666 /wx:lianweikj
Dapper操作MySQL数据库获取JSON数据中文乱码
manongba · 260浏览 · 发布于2020-03-27 +关注

在项目中利用Dapper将JSON数据存储到MySQL数据库,结果发现JSON数据中的中文乱码,特此记录,希望对存储JSON的童鞋能有所帮助,文中若有错误之处,还望批评指正。

Dapper获取JSON数据乱码(MySQL)

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

    public class Test
    {        public int Id { get; set; }        public string Data { get; set; }
    }

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

static void Main(string[] args)
{
    SimpleCRUD.SetDialect(SimpleCRUD.Dialect.MySQL);
    DefaultTypeMap.MatchNamesWithUnderscores = true;
    using (var conn = new MySqlConnection(@".....;charset=utf8mb4;SslMode=none;"))
    {
        var id = conn.Insert(new Test()
        {
            Data = JsonConvert.SerializeObject(new
            {
                name = "汪鹏"
            })
         });
        var result = conn.Get<Test>(id);
    }
    Console.ReadKey();
}

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

 

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

var result = conn.QueryFirstOrDefault<Test>("select * from Test where Id = @id", new { id });

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

var id = conn.Insert(new Test()

{

    Data = JsonConvert.SerializeObject(new

    {

        name = HttpUtility.UrlEncode("汪鹏")

    })

 });

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

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

总结

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

相关推荐

使用SELECT语句检索数据

奔跑的男人 · 803浏览 · 2019-06-03 09:33:43
部署MySQL延迟从库的几个好处

吴振华 · 662浏览 · 2019-05-14 21:57:51
MongoDB凭什么跻身数据库排行前五?

iamitnan · 722浏览 · 2019-06-18 10:04:56
Oracle开启和关闭的几种模式

qq2360248666 · 750浏览 · 2019-06-04 10:18:47
加载中

0评论

评论
分类专栏
小鸟云服务器
扫码进入手机网页