SQL语句解析:DESC LIMIT 1

跟着豆包学习SQL语句。

我来逐行、逐模块、通俗完整解析这条 SQL 语句,结合语法含义 + 业务逻辑,帮你彻底看懂:

一、整体功能(一句话总结)

从原材料出库主表中,查询 包含指定编码规则的领料单号 的 最新 1 条记录,只返回:出库单号、操作日期 两个字段。

数据库环境:PostgreSQL(PG 库)(双引号引用字段 / 表名、|| 字符串拼接是 PG 标准语法)

二、逐部分拆解解析

完整 SQL:

sql 复制代码
SELECT "c_StockOutOrder","d_OperaterDate"

FROM "MM_RawMaterialOutM"

WHERE "c_StockOutOrder"  LIKE

    (SELECT '%'||"c_SValue"||'%' FROM "AA_Basic_EncodingRulesDetails"  WHERE "c_CodeName"='领料单号' AND "i_Sequence"='1')

ORDER BY "c_StockOutOrder" DESC,"d_OperaterDate" DESC

LIMIT 1

1、查询字段:SELECT子句

SELECT "c_StockOutOrder","d_OperaterDate"

  • 作用:指定要查询返回的两个字段

  • 字段含义:

    • c_StockOutOrder:出库单号 / 领料单号(核心业务单号)

    • d_OperaterDate:操作日期(出库操作的时间)

  • 双引号 " ":PG 中用来标记标识符(字段名 / 表名),避免和数据库关键字冲突。

2. 数据源:FROM 子句

sql 复制代码
FROM "MM_RawMaterialOutM"
  • 表名:MM_RawMaterialOutM → 原材料出库主表

  • 作用:指定数据从「原材料出库单」这个主表中查询。

3. 过滤条件:WHERE + 子查询(核心逻辑)

sql 复制代码
WHERE "c_StockOutOrder" LIKE

    (SELECT '%'||"c_SValue"||'%' FROM "AA_Basic_EncodingRulesDetails"  WHERE "c_CodeName"='领料单号' AND "i_Sequence"='1')

① 外层条件:LIKE 模糊匹配

"c_StockOutOrder" LIKE 模糊值含义:出库单号 包含 后面子查询返回的字符串(模糊查询)

② 内层子查询:动态生成模糊匹配规则

sql 复制代码
SELECT '%'||"c_SValue"||'%'

FROM "AA_Basic_EncodingRulesDetails" 

WHERE "c_CodeName"='领料单号' AND "i_Sequence"='1'
  1. 表名:AA_Basic_EncodingRulesDetails → 系统编码规则明细表(存储单据编号的生成规则)

  2. 过滤条件:

    • c_CodeName='领料单号':找「领料单号」的编码规则

    • i_Sequence='1':找规则序号为 1 的配置

  3. 字符串拼接:%||c_SValue||%

    • ||:PG 的字符串拼接符

    • 效果:把查询到的 c_SValue 包装成 %xxx% 格式(标准 SQL 模糊匹配通配符)

    • 例子:如果子查询查到 c_SValue='LL',则拼接成 %LL%

③整体 WHERE 逻辑

出库单号 包含 编码规则表中「领料单号」规则配置的字符

4. 排序:ORDER BY 子句

sql 复制代码
ORDER BY "c_StockOutOrder" DESC,"d_OperaterDate" DESC
  • 排序规则:降序 DESC(最新的排在最前面)

  • 第一排序:按 出库单号 降序

  • 第二排序:按 操作日期 降序

  • 目的:把最新创建、最新操作的出库单放在结果集第一条

5. 限制返回条数:LIMIT 1

LIMIT 1

  • 作用:只返回排序后的第一条记录

  • 最终效果:拿到符合规则的最新 1 条原材料出库单

三、关键语法 & 业务补充

1. 必须满足的前提

子查询 必须返回 1 行 1 列(单个值),否则 SQL 会报错。 因为 LIKE 只能匹配一个模糊规则。

2. 业务场景解读

这条 SQL 一般用于:获取系统中,符合领料单号编码规则的最后一笔原材料出库记录。

3. 举个例子帮你理解

假设子查询返回:%LL%

那么整条 SQL 等价于:

sql 复制代码
SELECT 出库单号,操作日期

FROM 原材料出库主表

WHERE 出库单号 LIKE '%LL%'

ORDER BY 出库单号 DESC,操作日期 DESC

LIMIT 1

四、总结

数据源:原材料出库主表过滤规则:出库单号包含「领料单号编码规则」配置的字符排序:最新的出库单排第一结果:仅返回最新 1 条符合条件的 出库单号 + 操作日期

相关推荐
ccddsdsdfsdf7 小时前
DBeaver怎么链接mongoDB
数据库·mongodb
丷丩8 小时前
Postgresql基础实践教程(十一)各种Join
数据库·postgresql·join
星夜夏空998 小时前
FreeRTOS学习(4)——内存映射
数据库·学习·mongodb
TheRouter9 小时前
AI Agent 记忆体系建设实战:短期、长期与工作记忆的工程实现
数据库·人工智能·oracle
Omics Pro9 小时前
首个!外源天然产物综合性代谢图谱
数据库·人工智能·算法·机器学习·r语言
唐青枫9 小时前
MySQL EXISTS 详解:存在性判断、NOT EXISTS 与实战示例
sql·mysql
JAVA面经实录91710 小时前
Hibernate面试题库
数据库·oracle·hibernate
迷枫71210 小时前
DM8 目录结构与常用排查入口梳理
服务器·数据库
Mr.Daozhi12 小时前
RAG 进阶实战:跑通 Demo 后我连续翻了 6 次车,逐一修复才真正可用(含 Gradio Web 版)
前端·数据库·langchain·大模型·gradio·rag·科研工具
小程故事多_8012 小时前
Claude Code自定义workflow skills用法
数据库·人工智能·智能体