欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

MySQL插入json问题

程序员文章站 2022-11-11 13:16:39
在mysql5.7.8之后开始支持一种可高效获取json文本中数据的原生json类型,该类型具有以下优点: 存储时自动验证,验证不通过将报错 更好的存储结构...

在mysql5.7.8之后开始支持一种可高效获取json文本中数据的原生json类型,该类型具有以下优点:

  • 存储时自动验证,验证不通过将报错
  • 更好的存储结构。采用一种针对告诉读取json文本元素的内部结构进行存储。新的服务器是以二进制的格式读取一个json文本,而不是以字符串格式读取然后进行转换。这种二进制格式允许服务器在文本中通过键或者数组索引获取其子对象(嵌套数组)而不需要读取全部值

另外,系统对json格式做了一些限制:

  • json文本的最大长度取决有系统常量:max_allowed_packet。该值仅在服务器进行存储的时候进行限制,在内存中进行计算的时候是允许超过该值的。
  • json列不可有默认值
  • json列与其他二进制类型列一样是无法创建索引。但是可以从json列中所存储的文本中某些表列值进行创建索引。mysql最优控制器同样在通过json表达创建的索引中进行查询。

在插入json数据的时候遇到的问题

you have an error in your sql syntax; check the manual that corresponds to your mysql server version for the right syntax to use near ‘{

插入代码

insert into `players` (`id`,`player_and_games`) values(1,{
  "id":1,
  "name":"aaa",
  "games_played":{
    "battlefiedld":{
      "weapon":"adsf",
      "level":20
    },
    "crazy":{
      "weapon":"adsf",
      "level":20
    }
  }
})

存在问题,json没有用引号,正确的方式如下

insert into `players` (`id`,`player_and_games`) values(1,'{
  "id":1,
  "name":"aaa",
  "games_played":{
    "battlefiedld":{
      "weapon":"adsf",
      "level":20
    },
    "crazy":{
      "weapon":"adsf",
      "level":20
    }
  }
}')

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对的支持。如果你想了解更多相关内容请查看下面相关链接