mysql 5.7版本数据库json字段筛选

-- 创建测试表
CREATE TABLE `tab_json` (
  `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '主键id',
  `data` json DEFAULT NULL COMMENT 'json字符串',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

数据如下:

id   data
2    {"Tel": "22", "name": "cc", "address": "宁波"}
3    {"Tel": "33", "name": "yy", "address": "杭州"}
4    {"Tel": "44", "name": "c", "address": "宁波"}

使用如下两种语法的语句即可

select * from tab_json  where json_extract(data,'$.name') = 'cc'


select * from tab_json where data->'$.name' = 'cc'

或者直接创建虚拟列,查询对应列字段即可

CREATE TABLE `test` (
  `id` bigint(20) NOT NULL COMMENT '主键',
  `sub_json_data` json DEFAULT NULL COMMENT '提交的json数据',
  `name` varchar(255) GENERATED ALWAYS AS (json_extract(`sub_json_data`,'$.name')) STORED COMMENT '虚拟字段查询用',
  PRIMARY KEY (`id`) USING BTREE,
  UNIQUE KEY `idx_formKey_and_json_name` (`form_key`,`name`) USING BTREE
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 ROW_FORMAT=DYNAMIC COMMENT='测试';

stored 和 virtual的区别
 

在mysql5.7支持2种虚拟列virtual columns 和 stored columns 。两者的区别是virtual 只是在读行的时候计算结果,但在物理上是不存储,因此不占存储空间,且仅在InnoDB引擎上建二级索引,而stored 则是当行数据进行插入或更新时计算并存储的,是需要占用物理空间的,支持在MyISAM和InnoDB引擎创建索引

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值