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 条符合条件的 出库单号 + 操作日期

相关推荐
倔强的石头_2 天前
《Kingbase护城河》——数据库存储空间全景探测与精细化瘦身实战
数据库
云技纵横2 天前
唯一索引 INSERT 死锁实战:5 秒复现交叉插入的 S 锁循环等待
sql·mysql
冬奇Lab2 天前
每日一个开源项目(第134篇):Zvec - 阿里开源的嵌入式向量数据库,向量搜索界的 SQLite
数据库·人工智能·llm
ClouGence3 天前
Oracle CDC 架构优化:从主库直连到 DataGuard 备库同步
数据库·后端·oracle
无响应de神3 天前
三、用户与权限管理
数据库·mysql
麦聪聊数据4 天前
数据服务化时代:企业数据能力输出的核心路径
数据库
shushangyun_4 天前
2026年快消品B2B系统推荐:支持终端门店订货、促销政策自动化的工具?
java·运维·网络·数据库·人工智能·spring·自动化
DARLING Zero two♡4 天前
【MySQL数据库】数据类型与表约束
数据库·mysql
曹牧4 天前
Oracle EXPLAIN PLAN
数据库·oracle
BD_Marathon4 天前
SQL学习指南——视图
数据库·sql