已知mysql的表结构为CREATE TABLE `dtx_verify_rule_type` ( `id` varchar(40) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NOT NULL COMMENT '主键id', `business_id` varchar(40) COLLATE utf8mb4_general_ci DEFAULT NULL COMMENT '业务id', `type_name` varchar(50) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NOT NULL COMMENT '规则类型名称', `product_class_codes` json DEFAULT NULL COMMENT '可生产对象类', `version` varchar(40) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci DEFAULT NULL COMMENT '版本号', `oid` varchar(40) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci DEFAULT NULL COMMENT '原始记录ID', `ack_state` tinyint(1) DEFAULT '0' COMMENT '确认状态:0-未确认(默认)、1-已确认', `ack_by` varchar(32) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci DEFAULT NULL COMMENT '确认人', `operate` tinyint(1) DEFAULT '-1' COMMENT '操作方式:-1-未变化(默认)、0-删除、1-新增、2-修改', `creator` varchar(32) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci DEFAULT NULL COMMENT '创建人', `creation_time` char(14) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci DEFAULT NULL COMMENT '创建时间', `modifier` varchar(32) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci DEFAULT NULL COMMENT '最后修改人', `modified_time` char(14) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci DEFAULT NULL COMMENT '最后修改时间', `valid` tinyint NOT NULL DEFAULT '1' COMMENT '合法标识', `ts` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '乐观锁', PRIMARY KEY (`id`) USING BTREE ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci ROW_FORMAT=DYNAMIC COMMENT='数据校验类型表,因采用mybatis-plus.暂不分表表示类型与交付阶段的关系';,product_class_codes 字段存储数据格式为:["project", "building", "floor", "partition", "shaft", "space", "system", "equipment"] ,怎么根据product_class_codes 查询"equipment"的数据,mysql实现
时间: 2024-03-21 10:43:39 浏览: 106
可以使用MySQL的JSON_CONTAINS函数来查询JSON类型的字段中是否包含某个值。具体的查询语句如下:
```
SELECT * FROM dtx_verify_rule_type WHERE JSON_CONTAINS(product_class_codes, '["equipment"]');
```
这条语句会查询出包含"equipment"的所有记录。如果要查询包含多个值的记录,可以使用JSON_CONTAINS_ANY函数,语法与JSON_CONTAINS类似。
相关问题
已知mysql的表结构为CREATE TABLE dtx_verify_rule_type ( id varchar(40) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NOT NULL COMMENT '主键id', business_id varchar(40) COLLATE utf8mb4_general_ci DEFAULT NULL COMMENT '业务id', type_name varchar(50) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NOT NULL COMMENT '规则类型名称', product_class_codes json DEFAULT NULL COMMENT '可生产对象类', version varchar(40) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci DEFAULT NULL COMMENT '版本号', oid varchar(40) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci DEFAULT NULL COMMENT '原始记录ID', ack_state tinyint(1) DEFAULT '0' COMMENT '确认状态:0-未确认(默认)、1-已确认', ack_by varchar(32) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci DEFAULT NULL COMMENT '确认人', operate tinyint(1) DEFAULT '-1' COMMENT '操作方式:-1-未变化(默认)、0-删除、1-新增、2-修改', creator varchar(32) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci DEFAULT NULL COMMENT '创建人', creation_time char(14) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci DEFAULT NULL COMMENT '创建时间', modifier varchar(32) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci DEFAULT NULL COMMENT '最后修改人', modified_time char(14) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci DEFAULT NULL COMMENT '最后修改时间', valid tinyint NOT NULL DEFAULT '1' COMMENT '合法标识', ts timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '乐观锁', PRIMARY KEY (id) USING BTREE ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci ROW_FORMAT=DYNAMIC COMMENT='数据校验类型表,因采用mybatis-plus.暂不分表表示类型与交付阶段的关系';,product_class_codes 字段存储数据格式为:["project", "building", "floor", "partition", "shaft", "space", "system", "equipment"] ,怎么根据product_class_codes 查询"equipment"的数据,mysql的in实现
可以使用MySQL的IN语句来查询包含"equipment"的记录,具体的查询语句如下:
```
SELECT * FROM dtx_verify_rule_type WHERE 'equipment' IN (SELECT JSON_UNQUOTE(JSON_EXTRACT(product_class_codes, '$[7]')));
```
这条语句会查询包含"equipment"的所有记录。其中,JSON_EXTRACT函数用于从JSON数组中获取指定索引位置的元素,JSON_UNQUOTE函数用于去掉元素值中的双引号,使其与字符串类型匹配。在这里,我们使用了IN语句来判断是否包含"equipment",注意需要将其包装在子查询中。
Oracle sql查询 判断dtx_trialtable的height字段,小于等于450值就为450,大于450并且小于等于750值就为750,大于750,并且小于等于900值就为900
可以使用CASE WHEN语句来实现,具体的SQL语句如下:
```
SELECT CASE
WHEN height <= 450 THEN 450
WHEN height > 450 AND height <= 750 THEN 750
WHEN height > 750 AND height <= 900 THEN 900
END AS new_height
FROM dtx_trialtable;
```
该查询语句会根据dtx_trialtable表中height字段的值,返回对应的新值new_height。如果height小于等于450,则new_height为450;如果height大于450并且小于等于750,则new_height为750;如果height大于750并且小于等于900,则new_height为900。
阅读全文