当前位置: 首页 > article >正文

sql难点

一、

假设你有一个查询,需要根据 id 是否为 null 来动态生成 SQL 条件:

xml复制

<select id="getResources" resultType="Resource">
    SELECT * FROM resources
    <where>
        <if test="id != null">
            and id <![CDATA[<>]]> #{id}
        </if>
    </where>
</select>

生成的 SQL

假设 id 的值为 123,生成的 SQL 将是:

sql复制

SELECT * FROM resources
WHERE id <> 123

如果 idnull,则不会生成任何条件,生成的 SQL 将是:

sql复制

SELECT * FROM resources

从表 resources 中选择所有列(* 表示所有列),但只选择那些 id 字段不等于 123 的记录。

二、

查询解释

sql复制

SELECT
    IFNULL(MAX(IFNULL(ORDER_NO, 0)), 0)
FROM
    scm_web_classify_tab
WHERE
    DELETE_FLAG = 0
    AND TENANT_ID = #{tenantId}
  1. IFNULL(ORDER_NO, 0)

    • 这个函数确保 ORDER_NO 如果为 NULL,则用 0 替代。这样可以避免 MAX 函数在处理 NULL 值时的问题。

  2. MAX(...)

    • 这个函数用于获取 ORDER_NO 的最大值。如果所有 ORDER_NO 都是 NULLMAX 函数会返回 NULL

  3. IFNULL(..., 0)

    • 这个函数确保如果 MAX 函数的结果是 NULL,则用 0 替代。这样可以确保最终结果总是返回一个数字,而不是 NULL

三、

SQL 片段解释

sql复制

CASE
    WHEN r.REPORT_TYPE = 3 THEN CONCAT(cci.REPORT_CYCLE_YEAR, '年', r.REPORT_NAME)
    WHEN r.REPORT_TYPE = 2 THEN CONCAT(cci.REPORT_CYCLE_YEAR, '年',
        CASE
            WHEN cci.REPORT_CYCLE_QUARTER = 1 THEN '第一季度'
            WHEN cci.REPORT_CYCLE_QUARTER = 2 THEN '第二季度'
            WHEN cci.REPORT_CYCLE_QUARTER = 3 THEN '第三季度'
            WHEN cci.REPORT_CYCLE_QUARTER = 4 THEN '第四季度'
        END
    )
    -- 可以继续添加其他条件
END

详细解释

  1. CASE WHEN

    • CASE 语句用于根据条件选择不同的值。

    • WHEN r.REPORT_TYPE = 3:如果 r.REPORT_TYPE 的值为 3,则执行 THEN 后面的表达式。

    • THEN CONCAT(cci.REPORT_CYCLE_YEAR, '年', r.REPORT_NAME):将 cci.REPORT_CYCLE_YEARr.REPORT_NAME 拼接成一个字符串,中间用 连接。

  2. 嵌套 CASE WHEN

    • WHEN r.REPORT_TYPE = 2 的情况下,进一步使用嵌套的 CASE 语句来处理季度的情况。

    • WHEN cci.REPORT_CYCLE_QUARTER = 1 THEN '第一季度':如果 cci.REPORT_CYCLE_QUARTER 的值为 1,则返回字符串 第一季度

    • 同样地,处理其他季度的情况。

四、

示例代码

xml复制

<if test="tableName=='zb_logistics_enterprises_manage' or tableName=='zb_logistics_park_base_run_monitor' or tableName=='zb_report_cold_chain_logistics_enterprises_info'">
    ${bColumnName},
    ec_lc.STATE lastCycleState,
</if>

详细解释

  1. bColumnName

    • bColumnName 是一个动态列名,它可能是通过某种逻辑动态生成的,或者从用户输入中获取的。

    • 使用 ${} 语法直接将 bColumnName 的值插入到 SQL 中。这允许你在运行时动态指定列名。

    • 例如,bColumnName 可能是 ec_lc.NAMEec_lc.ID 等,具体取决于业务需求。

table_a
Column NameData Type
idINT
nameVARCHAR
created_atDATETIME
 System.out.println("aColumnName: " + paramMap.get("aColumnName"));
        System.out.println("bColumnName: " + paramMap.get("bColumnName"));

假设 table_a 的列名是 id, name, created_at,则输出可能是:

aColumnName: a.id,a.name,a.created_at
bColumnName: b.id1,b.name1,b.created_at1

http://www.kler.cn/a/544200.html

相关文章:

  • 在anaconda环境中构建flask项目的exe文件
  • CANMV K230入手体验(1)u盘安装镜像
  • OpenGL-基础知识(更新中)
  • 【Stable Diffusion模型测试】测试ControlNet,没有线稿图?
  • 【云安全】云原生-K8S- kubeconfig 文件泄露
  • python-leetcode-单词搜索
  • 微服务SpringCloud Alibaba组件nacos教程【详解naocs基础使用、服务中心配置、集群配置,附有案例+示例代码】
  • 网络分析仪如何看驻波
  • Datawhale Ollama教程笔记2
  • JVM的类加载器
  • Unity中Timeline和Cinemachine制作2D动画:镜头篇
  • 幂等性解决方案(消息队列例子)
  • Python爬虫:高效获取1688商品详情的实战指南
  • vue3: const一个function怎么写呢?
  • Mysql优化的查询语句(1)
  • 路由过滤方法与常用工具
  • DeepSeek是如何通过“蒸馏”技术打造自己的AI模型
  • React中PureComponent的用法
  • 图书管理项目(spring boot + Vue)
  • KOA优化最近邻分类预测matlab
  • flask和django的对比
  • Unity中实现动态图集算法
  • 分布式锁有哪些
  • 安科瑞光伏发电防逆流解决方案--守护电网安全,提升能源效率
  • Rust 文件读取:实现我们的 “迷你 grep”
  • 迅为RK3568开发板篇OpenHarmony实操HDF驱动配置LED-LED测试