mysql json invalid json text,MySQL JSON

MySQL5.7.7 labs版本开始在InnoDB存储引擎上提供原生JSON类型的支持,JSON值将不再以字符串的形式存储,而是采用一种允许快速读取文本元素(document elements)的内部二进制(internal binary)格式。在JSON列插入或更新的时候将自动验证JSON文本,未通过验证的文本将产生一个错误信息,JSON文本采用标准的创建方式,可使用大多数的比较操作符进行比较操作。

# 查看MySQL版本

$ mysql -V

mysql Ver 14.14 Distrib 5.7.25, for Linux (x86_64) using EditLine wrapper

# 查看MySQL版本

$ mysql --version

mysql Ver 14.14 Distrib 5.7.25, for Linux (x86_64) using EditLine wrapper

-- 查看MySQL版本

SELECT VERSION();

5.7.20-log

在此之前,我们通常会使用varchar或text数据类型来存储JSON格式的数据。以前的方式是需要先从MySQL中读出来,然后在代码中修改后再存入,非常麻烦而且不科学。虽然MySQL有了原生的JSON数据类型后,但不知道性能如何呢?

优势特点

JSON类型与varchar和text类型相比,有什么好处呢?

JSON数据类型的列会自动校验数据是否为JSON格式,若不是则会报错。

MySQL提供了一组操作JSON数据的内置函数

存储在JSON列中的数据被转换成内部的存储格式,优化了存储格式,允许快速读取。

JSON数据有效性检查,Blob类型无法在数据库层做这样的约束性检查。

JSON数据查询是不需要遍历所有字符串,提升了查询性能。

JSON数据支持索引,可以通过虚拟列对JSON部分数据进行索引。

JSON数据格式

# 连接数据库

$ mysql -u username -p

# 查看所有数据库

$ show databases;

# 创建数据库

$ create database test;

# 选择数据库

$ use test;

如果不是十分熟悉数据库操作,可参见《MySQL命令》。

-- 创建数据表

DROP TABLE IF EXISTS `game_config`;

CREATE TABLE IF NOT EXISTS `game_config`(

`id` int(11) unsigned NOT NULL PRIMARY KEY AUTO_INCREMENT,

`name` varchar(32) NOT NULL DEFAULT "",

`title` varchar(32) NOT NULL DEFAULT "",

`config` text DEFAULT NULL,

`remark` varchar(255) NOT NULL DEFAULT ""

)ENGINE=Innodb DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci;

-- 修改数据列的数据类型

ALTER TABLE `game_config` MODIFY `config` json;

-- 插入数据记录

INSERT INTO `game_config`(`name`,`title`,`config`)

VALUE('version','版本','{"app_version":"1.0.0", "res_version":"1.0.0"}');

INSERT INTO `game_config`(`name`,`title`,`config`)

VALUE('game','游戏','{"game_id":"10000", "game_type":1, "game_kind":2}');

INSERT INTO `game_config`(`name`,`title`,`config`)

VALUE('login','登录','{"login_ip":"192.168.50.25", "login_port":9001, "api_url":"/api/game/login"}');

注意:

JSON列存储的必须是JSON格式数据,否则会报错。

JSON数据类型是没有默认值的

JOSN函数

MySQL中的JSON分为json array和json object两种类型,$表示整个json对象,在索引json array数据时使用下标,在索引json object数据时使用键值。

JSON_ARRAY(value1, value2, value3,...)

生成一个包含指定元素的JSON数组

mysql> SELECT JSON_ARRAY(1, "junchow", null, true, CURTIME());

+-------------------------------------------------+

| JSON_ARRAY(1, "junchow", null, true, CURTIME()) |

+-------------------------------------------------+

| [1, "junchow", null, true, "22:32:33.000000"] |

+-------------------------------------------------+

1 row in set (0.12 sec)

JSON_OBJECT(key1, value1, key2, value2,...)

生成一个包含KV键值对的json object,如果key为NULL或参数个数为奇数则抛错。

mysql> SELECT JSON_OBJECT("id", 1, "name", "alice");

+---------------------------------------+

| JSON_OBJECT("id", 1, "name", "alice") |

+---------------------------------------+

| {"id": 1, "name": "alice"} |

+---------------------------------------+

1 row in set (0.00 sec)

mysql> SELECT JSON_OBJECT("id", 1, "name", "alice", "nick");

ERROR 1582 (42000): Incorrect parameter count in the call to native function 'JSON_OBJECT'

mysql> SELECT JSON_OBJECT("id", 1, "name", "alice", null, "error");

ERROR 3158 (22032): JSON documents may not contain NULL member names.

CONVERT(json_string, JSON)

将JSON字符串转换为JSON对象格式

mysql> SELECT CONVERT('{"id":1, "name":"junchow"}', JSON);

+---------------------------------------------+

| CONVERT('{"id":1, "name":"junchow"}', JSON) |

+---------------------------------------------+

| {"id": 1, "name": "junchow"} |

+---------------------------------------------+

1 row in set (0.00 sec)

mysql> SELECT CONVERT('{id:1, name:"junchow"}', JSON);

ERROR 3141 (22032): Invalid JSON text in argument 1 to function cast_as_json: "Missing a name for object member." at position 1.

JSON_QUOTE(json_val)

将JSON对象转换为JSON字符串,通过双引号字符包装并转义内部引号和其他字符,然后将结果作为utf8mb4字符串返回,并将字符串引用为JSON值。若参数为NULL则返回NULL。

mysql> SELECT JSON_QUOTE('{id:1, name:"junchow"}');

+--------------------------------------+

| JSON_QUOTE('{id:1, name:"junchow"}') |

+--------------------------------------+

| "{id:1, name:\"junchow\"}" |

+--------------------------------------+

1 row in set (0.00 sec)

mysql> SELECT JSON_QUOTE('NULL');

+--------------------+

| JSON_QUOTE('NULL') |

+--------------------+

| "NULL" |

+--------------------+

1 row in set (0.00 sec)

JSON_CONTAINS(json_doc, val[, path])

查询json文档中是否在指定path上包含指定的数据,如果包含则返回1,否则返回0。如果有参数为NULL或者path不存在则返回NULL。

# 从game_config表的config字段中判断game_kind为2的记录是否存在

mysql> SELECT JSON_CONTAINS(`config`, '2', '$.game_kind') FROM `game_config` WHERE `name`='game';

心得体会

其实我个人第一次看到有人用MySQL去存储JSON类型的数据时,是一头的火,非常窝火,因为我要取出来然后在代码中解析然后再这样倒腾来倒腾去,非常麻烦。因为有NoSQL,存JSON干嘛不直接用MongoDB。不过有了原生的JSON函数支持,也逐渐开始学习适应。避开好恶,RDB和NoSQL应用场景是不同的,相煎何太急。同事很喜欢用MySQL去存配置,到我这里做数据统计时,又是一头的抓狂。哎,为了省事,其实很多时候并不省事儿。既然使用到RDB,具有关系属性的字段是可以提取出来的,变化的字段和简单的配置也是可以使用的。文章的内容也是用到学到,学到用到,慢慢增加积累,一味的为了知识而学习,是一种不良作风,实践是需要场景而非模拟,才能体会到它的价值所在。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Go语言(也称为Golang)是由Google开发的一种静态强类型、编译型的编程语言。它旨在成为一门简单、高效、安全和并发的编程语言,特别适用于构建高性能的服务器和分布式系统。以下是Go语言的一些主要特点和优势: 简洁性:Go语言的语法简单直观,易于学习和使用。它避免了复杂的语法特性,如继承、重载等,转而采用组合和接口来实现代码的复用和扩展。 高性能:Go语言具有出色的性能,可以媲美C和C++。它使用静态类型系统和编译型语言的优势,能够生成高效的机器码。 并发性:Go语言内置了对并发的支持,通过轻量级的goroutine和channel机制,可以轻松实现并发编程。这使得Go语言在构建高性能的服务器和分布式系统时具有天然的优势。 安全性:Go语言具有强大的类型系统和内存管理机制,能够减少运行时错误和内存泄漏等问题。它还支持编译时检查,可以在编译阶段就发现潜在的问题。 标准库:Go语言的标准库非常丰富,包含了大量的实用功能和工具,如网络编程、文件操作、加密解密等。这使得开发者可以更加专注于业务逻辑的实现,而无需花费太多时间在底层功能的实现上。 跨平台:Go语言支持多种操作系统和平台,包括Windows、Linux、macOS等。它使用统一的构建系统(如Go Modules),可以轻松地跨平台编译和运行代码。 开源和社区支持:Go语言是开源的,具有庞大的社区支持和丰富的资源。开发者可以通过社区获取帮助、分享经验和学习资料。 总之,Go语言是一种简单、高效、安全、并发的编程语言,特别适用于构建高性能的服务器和分布式系统。如果你正在寻找一种易于学习和使用的编程语言,并且需要处理大量的并发请求和数据,那么Go语言可能是一个不错的选择。
Go语言(也称为Golang)是由Google开发的一种静态强类型、编译型的编程语言。它旨在成为一门简单、高效、安全和并发的编程语言,特别适用于构建高性能的服务器和分布式系统。以下是Go语言的一些主要特点和优势: 简洁性:Go语言的语法简单直观,易于学习和使用。它避免了复杂的语法特性,如继承、重载等,转而采用组合和接口来实现代码的复用和扩展。 高性能:Go语言具有出色的性能,可以媲美C和C++。它使用静态类型系统和编译型语言的优势,能够生成高效的机器码。 并发性:Go语言内置了对并发的支持,通过轻量级的goroutine和channel机制,可以轻松实现并发编程。这使得Go语言在构建高性能的服务器和分布式系统时具有天然的优势。 安全性:Go语言具有强大的类型系统和内存管理机制,能够减少运行时错误和内存泄漏等问题。它还支持编译时检查,可以在编译阶段就发现潜在的问题。 标准库:Go语言的标准库非常丰富,包含了大量的实用功能和工具,如网络编程、文件操作、加密解密等。这使得开发者可以更加专注于业务逻辑的实现,而无需花费太多时间在底层功能的实现上。 跨平台:Go语言支持多种操作系统和平台,包括Windows、Linux、macOS等。它使用统一的构建系统(如Go Modules),可以轻松地跨平台编译和运行代码。 开源和社区支持:Go语言是开源的,具有庞大的社区支持和丰富的资源。开发者可以通过社区获取帮助、分享经验和学习资料。 总之,Go语言是一种简单、高效、安全、并发的编程语言,特别适用于构建高性能的服务器和分布式系统。如果你正在寻找一种易于学习和使用的编程语言,并且需要处理大量的并发请求和数据,那么Go语言可能是一个不错的选择。
Go语言(也称为Golang)是由Google开发的一种静态强类型、编译型的编程语言。它旨在成为一门简单、高效、安全和并发的编程语言,特别适用于构建高性能的服务器和分布式系统。以下是Go语言的一些主要特点和优势: 简洁性:Go语言的语法简单直观,易于学习和使用。它避免了复杂的语法特性,如继承、重载等,转而采用组合和接口来实现代码的复用和扩展。 高性能:Go语言具有出色的性能,可以媲美C和C++。它使用静态类型系统和编译型语言的优势,能够生成高效的机器码。 并发性:Go语言内置了对并发的支持,通过轻量级的goroutine和channel机制,可以轻松实现并发编程。这使得Go语言在构建高性能的服务器和分布式系统时具有天然的优势。 安全性:Go语言具有强大的类型系统和内存管理机制,能够减少运行时错误和内存泄漏等问题。它还支持编译时检查,可以在编译阶段就发现潜在的问题。 标准库:Go语言的标准库非常丰富,包含了大量的实用功能和工具,如网络编程、文件操作、加密解密等。这使得开发者可以更加专注于业务逻辑的实现,而无需花费太多时间在底层功能的实现上。 跨平台:Go语言支持多种操作系统和平台,包括Windows、Linux、macOS等。它使用统一的构建系统(如Go Modules),可以轻松地跨平台编译和运行代码。 开源和社区支持:Go语言是开源的,具有庞大的社区支持和丰富的资源。开发者可以通过社区获取帮助、分享经验和学习资料。 总之,Go语言是一种简单、高效、安全、并发的编程语言,特别适用于构建高性能的服务器和分布式系统。如果你正在寻找一种易于学习和使用的编程语言,并且需要处理大量的并发请求和数据,那么Go语言可能是一个不错的选择。
Go语言(也称为Golang)是由Google开发的一种静态强类型、编译型的编程语言。它旨在成为一门简单、高效、安全和并发的编程语言,特别适用于构建高性能的服务器和分布式系统。以下是Go语言的一些主要特点和优势: 简洁性:Go语言的语法简单直观,易于学习和使用。它避免了复杂的语法特性,如继承、重载等,转而采用组合和接口来实现代码的复用和扩展。 高性能:Go语言具有出色的性能,可以媲美C和C++。它使用静态类型系统和编译型语言的优势,能够生成高效的机器码。 并发性:Go语言内置了对并发的支持,通过轻量级的goroutine和channel机制,可以轻松实现并发编程。这使得Go语言在构建高性能的服务器和分布式系统时具有天然的优势。 安全性:Go语言具有强大的类型系统和内存管理机制,能够减少运行时错误和内存泄漏等问题。它还支持编译时检查,可以在编译阶段就发现潜在的问题。 标准库:Go语言的标准库非常丰富,包含了大量的实用功能和工具,如网络编程、文件操作、加密解密等。这使得开发者可以更加专注于业务逻辑的实现,而无需花费太多时间在底层功能的实现上。 跨平台:Go语言支持多种操作系统和平台,包括Windows、Linux、macOS等。它使用统一的构建系统(如Go Modules),可以轻松地跨平台编译和运行代码。 开源和社区支持:Go语言是开源的,具有庞大的社区支持和丰富的资源。开发者可以通过社区获取帮助、分享经验和学习资料。 总之,Go语言是一种简单、高效、安全、并发的编程语言,特别适用于构建高性能的服务器和分布式系统。如果你正在寻找一种易于学习和使用的编程语言,并且需要处理大量的并发请求和数据,那么Go语言可能是一个不错的选择。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值