mysql驱动类型
概述有的时候我们在操作数据库时会将两个或多个数据表关联起来通过一些条件筛选数据,在关联表时我们要遵循一些原则,这样会使我们编写的SQL 语句在效率上快很多。一、需要优化的查询使用explain常见的扫...
2024.11.15以前,我们一般选用 MySQL 的 VARCHAR 或 TEXT 等作为这类复合数据字段的类型。从5.7.8开始,MySQL将 JSON 作为标准的字段类型之一。
与JSON格式的纯文本字段相比,JSON类型的字段有以下优势:
自动校验JSON格式。如果添加的数据不符合JSON规范将会报错。注意:MySQL中合法的JSON字符串格式与我们通常处理的JSON数据可能有些不同。某些场景下,我们习惯将JSON字符串解析成对象({...})或数组([...]),而不考虑单个值的情况(如:“1”)。存储格式经过优化。读取JSON内容项的速度更快。因为MySQL提供的内部数据结构允许通过内容项的key或index直接访问目标数据,而无需将处理其它数据。比以前的上层应用读取整块内容再解析的方式更快。一、对记录的操作1.创建有json字段的表
-- 创建表 CREATE TABLE t_json(id INT PRIMARY KEY, sname VARCHAR(20) , info JSON);2.插入记录
-- 插入含有json数组的记录insert INTO t_json(id,sname,info) VALUES( 1, ‘name1‘, JSON_ARRAY(1, "abc", NULL, TRUE, CURTIME()));-- 插入含有json对象的记录insert INTO t_json(id,sname,info) VALUES( 2, ‘name2‘, JSON_OBJECT("age", 20, "time", now()));insert INTO t_json(id,sname,info) VALUES( 3, ‘name3‘, ‘{"age":20, "time":"2018-07-14 10:52:00"}‘);3.查询记录
-- 查询记录select sname,JSON_EXTRACT(info,‘$.age‘) FROM t_json;select sname,info->‘$.age‘ FROM t_json;-- 查询keySELECT id,json_keys(info) FROM t_json;4.修改记录
-- 增加键update t_json SET info = json_set(info,‘$.ip‘,‘192.168.1.1‘) WHERE id = 2;-- 变更值update t_json SET info = json_set(info,‘$.ip‘,‘192.168.1.2‘) WHERE id = 2;-- 删除键update t_json SET info = json_remove(info,‘$.ip‘) WHERE id = 2;二、创建json值函数1.JSON_ARRAY 生成json数组
-- JSON_ARRAY(val1,val2,val3...)-- 生成一个包含指定元素的json数组。select JSON_ARRAY(1, "abc", NULL, TRUE, CURTIME()); -- [1, "abc", null, true, "10:37:08.000000"]2.JSON_OBJECT 生成json对象
-- JSON_OBJECT(key1,val1,key2,val2...)-- 生成一个包含指定K-V对的json object。如果有key为NULL或参数个数为奇数,则抛错。select JSON_OBJECT(‘age‘, 20, ‘time‘, now()); -- {"id": 87, "name": "carrot"}3.JSON_QUOTE 加"号
-- JSON_QUOTE(json_val)-- 将json_val用"号括起来。select JSON_QUOTE(‘[1,2,3]‘); -- "[1,2,3]" 三、搜索json值函数1.JSON_CONTAINS 指定数据是否存在
set @j = ‘{"a": 1, "b": 2, "c": {"d": 4}}‘;-- JSON_CONTAINS(json_doc, val[, path])-- 查询json文档是否在指定path包含指定的数据,包含则返回1,否则返回0。如果有参数为NULL或path不存在,则返回NULL。select JSON_CONTAINS(@j, ‘4‘, ‘$.c.d‘); -- 12.JSON_CONTAINS_PATH 指定路径是否存在
-- JSON_CONTAINS_PATH(json_doc, one_or_all, path[, path] ...)-- 查询是否存在指定路径,存在则返回1,否则返回0。如果有参数为NULL,则返回NULL。-- one_or_all只能取值"one"或"all",one表示只要有一个存在即可;all表示所有的都存在才行。select JSON_CONTAINS_PATH(@j, ‘one‘, ‘$.a‘, ‘$.e‘); -- 1SELECT JSON_CONTAINS_PATH(@j, ‘all‘, ‘$.a‘, ‘$.c.d‘); -- 13.JSON_EXTRACT 查找所有指定数据
-- JSON_EXTRACT(json_doc, path[, path] ...)-- 从json文档里抽取数据。如果有参数有NULL或path不存在,则返回NULL。如果抽取出多个path,则返回的数据封闭在一个json array里。set @j2 = ‘[10, 20, [30, 40]]‘;select JSON_EXTRACT(‘[10, 20, [30, 40]]‘, ‘$[1]‘); -- 20SELECT JSON_EXTRACT(‘[10, 20, [30, 40]]‘, ‘$[1]‘, ‘$[0]‘); -- [20, 10]select JSON_EXTRACT(‘[10, 20, [30, 40]]‘, ‘$[2][*]‘); -- [30, 40]4.JSON_KEYS 查找所有指定键值
-- JSON_KEYS(json_doc[, path])-- 获取json文档在指定路径下的所有键值,返回一个json array。如果有参数为NULL或path不存在,则返回NULL。select JSON_KEYS(‘{"a": 1, "b": {"c": 30}}‘); -- ["a", "b"]select JSON_KEYS(‘{"a": 1, "b": {"c": 30}}‘, ‘$.b‘); -- ["c"]select id,json_keys(info) FROM t_json;5.JSON_SEARCH 查找所有指定值的位置
-- JSON_SEARCH(json_doc, one_or_all, search_str[, escape_char[, path] ...])-- 查询包含指定字符串的paths,并作为一个json array返回。如果有参数为NUL或path不存在,则返回NULL。-- one_or_all:"one"表示查询到一个即返回;"all"表示查询所有。-- search_str:要查询的字符串。 可以用LIKE里的‘%‘或‘_’匹配。-- path:在指定path下查。SET @j3 = ‘["abc", [{"k": "10"}, "def"], {"x":"abc"}, {"y":"bcd"}]‘;select JSON_SEARCH(@j3, ‘one‘, ‘abc‘); -- "$[0]"select JSON_SEARCH(@j3, ‘all‘, ‘abc‘); -- ["$[0]", "$[2].x"]select JSON_SEARCH(@j3, ‘all‘, ‘abc‘, NULL, ‘$[2]‘); -- "$[2].x"select JSON_SEARCH(@j3, ‘all‘, ‘10‘); -- "$[1][0].k"select JSON_SEARCH(@j3, ‘all‘, ‘%b%‘); -- ["$[0]", "$[2].x", "$[3].y"]select JSON_SEARCH(@j3, ‘all‘, ‘%b%‘, NULL, ‘$[2]‘); -- "$[2].x"四、修改json值函数1.JSON_ARRAY_APPEND 指定位置追加数组元素
-- JSON_ARRAY_APPEND(json_doc, path, val[, path, val] ...)-- 在指定path的json array尾部追加val。如果指定path是一个json object,则将其封装成一个json array再追加。如果有参数为NULL,则返回NULL。SET @j4 = ‘["a", ["b", "c"], "d"]‘;-- select JSON_ARRAY_APPEND(@j4, ‘$[1][0]‘, 3); -- ["a", [["b", 3], "c"], "d"]SET @j5 = ‘{"a": 1, "b": [2, 3], "c": 4}‘;select JSON_ARRAY_APPEND(@j5, ‘$.b‘, ‘x‘); -- {"a": 1, "b": [2, 3, "x"], "c": 4} select JSON_ARRAY_APPEND(@j5, ‘$.c‘, ‘y‘); -- {"a": 1, "b": [2, 3], "c": [4, "y"]}select JSON_ARRAY_APPEND(@j5, ‘$‘, ‘z‘); -- [{"a": 1, "b": [2, 3], "c": 4}, "z"]2.JSON_ARRAY_INSERT 指定位置插入数组元素
-- JSON_ARRAY_INSERT(json_doc, path, val[, path, val] ...)-- 在path指定的json array元素插入val,原位置及以右的元素顺次右移。如果path指定的数据非json array元素,则略过此val;如果指定的元素下标超过json array的长度,则插入尾部。SET @j6 = ‘["a", {"b": [1, 2]}, [3, 4]]‘;select JSON_ARRAY_INSERT(@j6, ‘$[1]‘, ‘x‘); -- ["a", "x", {"b": [1, 2]}, [3, 4]]select JSON_ARRAY_INSERT(@j6, ‘$[100]‘, ‘x‘); -- ["a", {"b": [1, 2]}, [3, 4], "x"]select JSON_ARRAY_INSERT(@j6, ‘$[1].b[0]‘, ‘x‘); -- ["a", {"b": ["x", 1, 2]}, [3, 4]]select JSON_ARRAY_INSERT(@j6, ‘$[0]‘, ‘x‘, ‘$[3][1]‘, ‘y‘); -- ["x", "a", {"b": [1, 2]}, [3, "y", 4]]3.JSON_INSERT 指定位置插入
-- JSON_INSERT(json_doc, path, val[, path, val] ...)-- 在指定path下插入数据,如果path已存在,则忽略此val(不存在才插入)。SET @j7 = ‘{ "a": 1, "b": [2, 3]}‘;select JSON_INSERT(@j7, ‘$.a‘, 10, ‘$.c‘, ‘[true, false]‘); -- {"a": 1, "b": [2, 3], "c": "[true, false]"}4.JSON_REPLACE 指定位置替换
-- JSON_REPLACE(json_doc, path, val[, path, val] ...)-- 替换指定路径的数据,如果某个路径不存在则略过(存在才替换)。如果有参数为NULL,则返回NULL。select JSON_REPLACE(@j7, ‘$.a‘, 10, ‘$.c‘, ‘[true, false]‘); -- {"a": 10, "b": [2, 3]}5.JSON_SET 指定位置设置
-- JSON_SET(json_doc, path, val[, path, val] ...)-- 设置指定路径的数据(不管是否存在)。如果有参数为NULL,则返回NULL。select JSON_SET(@j7, ‘$.a‘, 10, ‘$.c‘, ‘[true, false]‘); -- {"a": 10, "b": [2, 3], "c": "[true, false]"}6.JSON_MERGE 合并
-- JSON_MERGE(json_doc, json_doc[, json_doc] ...)-- merge多个json文档。规则如下:-- 如果都是json array,则结果自动merge为一个json array;-- 如果都是json object,则结果自动merge为一个json object;-- 如果有多种类型,则将非json array的元素封装成json array再按照规则一进行mege。select JSON_MERGE(‘[1, 2]‘, ‘[true, false]‘); -- [1, 2, true, false]select JSON_MERGE(‘{"name": "x"}‘, ‘{"id": 47}‘); -- {"id": 47, "name": "x"}select JSON_MERGE(‘1‘, ‘true‘); -- [1, true]select JSON_MERGE(‘[1, 2]‘, ‘{"id": 47}‘); -- [1, 2, {"id": 47}]7.JSON_REMOVE 指定位置移除
-- JSON_REMOVE(json_doc, path[, path] ...)-- 移除指定路径的数据,如果某个路径不存在则略过此路径。如果有参数为NULL,则返回NULL。SET @j8 = ‘["a", ["b", "c"], "d"]‘;select JSON_REMOVE(@j8, ‘$[1]‘); -- ["a", "d"]8.JSON_UNQUOTE 去"号
-- JSON_UNQUOTE(val)-- 去掉val的引号。如果val为NULL,则返回NULL。select JSON_UNQUOTE("\"123\""); -- 123五、返回json值属性的函数1.JSON_DEPTH 深度
-- JSON_DEPTH(json_doc)-- 获取json文档的深度。如果参数为NULL,则返回NULL。-- 空的json array、json object或标量的深度为1。select JSON_DEPTH(‘{}‘), JSON_DEPTH(‘[]‘), JSON_DEPTH(‘true‘); -- 1 1 1SELECT JSON_DEPTH(‘[10, 20]‘), JSON_DEPTH(‘[[], {}]‘); -- 2 2SELECT JSON_DEPTH(‘[10, {"a": 20}]‘); -- 32.JSON_LENGTH 长度
-- JSON_LENGTH(json_doc[, path])-- 获取指定路径下的长度。如果参数为NULL,则返回NULL。 -- 长度的计算规则:-- 标量的长度为1;-- json array的长度为元素的个数;-- json object的长度为key的个数。select JSON_LENGTH(‘[1, 2, {"a": 3}]‘); -- 3SELECT JSON_LENGTH(‘{"a": 1, "b": {"c": 30}}‘); -- 2SELECT JSON_LENGTH(‘{"a": 1, "b": {"c": 30}}‘, ‘$.b‘); -- 13.JSON_TYPE 类型
-- JSON_TYPE(json_val)-- 获取json文档的具体类型。如果参数为NULL,则返回NULL。select JSON_TYPE(‘[1,2]‘); -- ARRAY4.JSON_VALID 是否有效json格式
-- JSON_VALID(val)-- 判断val是否为有效的json格式,是为1,不是为0。如果参数为NUL,则返回NULL。select JSON_VALID(‘{"a": 1}‘); -- 1SELECT JSON_VALID(‘hello‘), JSON_VALID(‘"hello"‘); -- 1六、函数说明后面会分享更多devops和DBA方面的内容,感兴趣的朋友可以关注一下~
概述有的时候我们在操作数据库时会将两个或多个数据表关联起来通过一些条件筛选数据,在关联表时我们要遵循一些原则,这样会使我们编写的SQL 语句在效率上快很多。一、需要优化的查询使用explain常见的扫...
2024.11.15很多用过ElasticSearch的人都知道,es检索的效率相对较好,可以在海量的数据中实现秒级检索,并给出相关的评分。很多小伙伴可能会有疑问,底层实现使用的mysql、tidb、oceanbase等...
2024.11.12CREATE TABLE IF NOT EXISTS `test_compress` ( `id` bigint(20) NOT NULL AUTO_INCREMENT, `content` blob...
2024.11.15数据库优化sql语句优化 索引优化 加缓存 读写分离 分区 分布式数据库(垂直切分) 水平切分 MyISAM和InnoDB的区别: 1. InnoDB支持事务,MyISAM不支持,对于InnoDB每一...
2024.11.15概述MySQL在5.5.3之后增加了这个utf8mb4的编码,mb4就是most bytes 4的意思,专门用来兼容四字节的unicode。好在utf8mb4是utf8的超集,除了将编码改为utf8m...
2024.11.15