Java @Mapper 使用注解的方式注入SQL

MySQL 的 JSON 数据类型(从 MySQL 5.7.8 开始支持)允许你在表中存储和处理 JSON 格式的数据。

JSON 数据类型提供了灵活性,但应谨慎使用。对于需要复杂查询、索引或关系约束的数据,传统的关系表结构通常是更好的选择。

mysql中in语句的处理。

一、例如SQL:update bill_main set bill_state = '00' where bill_no in ();

处理如下:

复制代码
@Update(" update bill_main set bill_state = '00' where  bill_no in <foreach collection='billNoList' item='billNo' open='(' separator=',' close=')'> #{billNo}</foreach> ")
Boolean approveReject(@Param("billNoList") List<String> billNoList);
java 复制代码
 @Update(" update bill_main set bill_state = '00' where  bill_no in <foreach collection='billNoList' item='billNo' open='(' separator=',' close=')'> #{billNo}</foreach> ")
    Boolean approveReject(@Param("billNoList") List<String> billNoList);

二、遇到数据类为JOSN的SQL的处理(t3)

SELECT t1.id,

t1.bill_no,

t1.process_instance_id,

t1.process_definition_id,

t1.process_deployment_id,

t1.approve_id,

t1.remark,

t1.enabled_flag,

json_unquote(json_extract(json_extract(t2.BILL_DATA,'.comBasicInfo'),'[0].comApplyUserId')) comApplyUserId,

json_unquote(json_extract(json_extract(t2.BILL_DATA,'.comBasicInfo'),'[0].comApplyUserName')) comApplyUserName,

json_unquote(json_extract(json_extract(t2.BILL_DATA,'.comBasicInfo'),'[0].comApplyUserCode')) comApplyUserCode,

t3.hj_value, #工时

t3.yye04,#项目

t3.comSubCategoryCode #月份

FROM bill_main t1

LEFT JOIN bill_main_data t2 ON t1.id = t2.id

LEFT join (

SELECT

t.id,#单据号

jt.hj_value, #工时

jt.yye04,#项目

jt.comSubCategoryCode #月份

FROM bill_main_data t,

JSON_TABLE(

t.BILL_DATA->'$.jyInfo',

'$[*]' COLUMNS (

idx FOR ORDINALITY,

hj_value VARCHAR(100) PATH '$.hj',

yye04 VARCHAR(100) PATH '$.yye04',

comSubCategoryCode VARCHAR(100) PATH '$.comSubCategoryCode'

) ) AS jt

) t3

on t1.id = t3.id

sql 复制代码
SELECT  t1.id,
        t1.bill_no,
        t1.process_instance_id,
        t1.process_definition_id,
        t1.process_deployment_id,
        t1.approve_id,
        t1.remark,
        t1.enabled_flag,
        json_unquote(json_extract(json_extract(t2.BILL_DATA,'$.comBasicInfo'),'$[0].comApplyUserId')) comApplyUserId,
        json_unquote(json_extract(json_extract(t2.BILL_DATA,'$.comBasicInfo'),'$[0].comApplyUserName')) comApplyUserName,
        json_unquote(json_extract(json_extract(t2.BILL_DATA,'$.comBasicInfo'),'$[0].comApplyUserCode')) comApplyUserCode,
        t3.hj_value, #工时
        t3.yye04,#项目
        t3.comSubCategoryCode #月份
        FROM bill_main t1
        LEFT JOIN bill_main_data t2 ON t1.id = t2.id
         LEFT join (
         SELECT 
                  t.id,#单据号
                  jt.hj_value, #工时
                  jt.yye04,#项目
                  jt.comSubCategoryCode #月份
                FROM bill_main_data t,
                JSON_TABLE(
                    t.BILL_DATA->'$.jyInfo',
                    '$[*]' COLUMNS (
                        idx FOR ORDINALITY,
                        hj_value VARCHAR(100) PATH '$.hj',
                        yye04 VARCHAR(100) PATH '$.yye04',
                        comSubCategoryCode VARCHAR(100) PATH '$.comSubCategoryCode'
                    ) ) AS jt
         ) t3
         on t1.id = t3.id

三、mysql json 数据类型的使用示例

sql 复制代码
-- 创建电商商品表
CREATE TABLE products (
    id INT PRIMARY KEY,
    name VARCHAR(100),
    attributes JSON,
    price DECIMAL(10,2)
);

-- 插入商品数据
INSERT INTO products VALUES
(1, '手机', '{"brand": "苹果", "color": "黑色", "storage": "128GB", "specs": {"ram": "4GB", "cpu": "A15"}}', 6999),
(2, '笔记本', '{"brand": "戴尔", "color": "银色", "storage": "512GB", "specs": {"ram": "16GB", "cpu": "i7"}}', 8999);

-- 复杂查询:查找品牌是苹果且颜色是黑色的产品
SELECT name, price FROM products
WHERE JSON_EXTRACT(attributes, '$.brand') = '苹果'
AND JSON_EXTRACT(attributes, '$.color') = '黑色';

-- 嵌套查询
SELECT name, attributes->'$.specs.cpu' AS cpu
FROM products;
相关推荐
天才奇男子16 小时前
HAProxy高级功能全解析
linux·运维·服务器·微服务·云原生
学嵌入式的小杨同学16 小时前
【Linux 封神之路】信号编程全解析:从信号基础到 MP3 播放器实战(含核心 API 与避坑指南)
java·linux·c语言·开发语言·vscode·vim·ux
酥暮沐17 小时前
iscsi部署网络存储
linux·网络·存储·iscsi
❀͜͡傀儡师17 小时前
centos 7部署dns服务器
linux·服务器·centos·dns
Dying.Light17 小时前
Linux部署问题
linux·运维·服务器
S190117 小时前
Linux的常用指令
linux·运维·服务器
小义_18 小时前
【RH134知识点问答题】第7章 管理基本存储
linux·运维·服务器
小天源18 小时前
Error 1053 Error 1067 服务“启动后立即停止” Java / Python 程序无法后台运行 windows nssm注册器下载与报错处理
开发语言·windows·python·nssm·error 1053·error 1067
梁洪飞18 小时前
内核的schedule和SMP多核处理器启动协议
linux·arm开发·嵌入式硬件·arm
_运维那些事儿18 小时前
VM环境的CI/CD
linux·运维·网络·阿里云·ci/cd·docker·云计算