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

相关推荐
城数派4 小时前
2025年全国地级市间驾车出行距离和出行时间矩阵数据
数据库·arcgis·信息可视化·数据分析
wgzrmlrm744 小时前
SQL实现按用户偏好进行分组汇总_自定义聚合规则
jvm·数据库·python
lzhdim5 小时前
SQL 入门 10:SQL 内置函数:数值、字符串与时间处理
前端·数据库·sql
QX_hao5 小时前
PGsql的常用命令(对比mysql)
数据库·mysql·pgsql
半点闲5 小时前
入门 SQLAlchemy 教程:从 0 到 1 创建数据库
数据库·python·sqlite·sqlalchemy
xcjbqd05 小时前
CSS如何给Bootstrap侧边菜单加图标_使用font-awesome结合CSS
jvm·数据库·python
KevinCh5 小时前
Vespa:面向 AI 时代的检索与排序服务平台
数据库
Rick19935 小时前
Redis查询为什么快
数据库·redis·缓存
fly spider5 小时前
MySQL索引篇
android·数据库·mysql