首页 > 数据库 > MySQL > 正文

MySQL插入json问题

2024-07-24 12:49:46
字体:
来源:转载
供稿:网友

在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 } }}')

总结

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

您可能感兴趣的文章:

用Python将mysql数据导出成json的方法Python3实现将本地JSON大数据文件写入MySQL数据库的方法PHP连接MySQL数据库并以json格式输出MySQL操作之JSON数据类型操作详解MySQL5.7 JSON类型使用详解利用java+mysql递归实现拼接树形JSON列表的方法示例Mysql5.7中JSON操作函数使用说明mysql5.6及以下版本如何查询数据库里的json简单谈谈MySQL5.7 JSON格式检索详解Mysql中的JSON系列操作函数android+json+php+mysql实现用户反馈功能方法解析
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表