用AI解决SQL语句解析及语法转换问题

以前读写SQL都会先搜索关键词相关语法,然后再逐句解析,就像拿着字典搞翻译。

现在遇到SQL语句,有个词记不清啥意思了,会把整条丢给豆包,让豆包给解析。

像这种类似1+1=2的问题,豆包解析的准确率还是蛮高的。

毕竟它再一本正经胡说八道,也不能把1+1说成=3吧?!

下面是一个解析结果:

一、原 SQL 语句解析

这是一条查询去重数据并生成连续行号的 SQL,核心功能拆解:

1、SELECT DISTINCT:对最终查询结果去重,排除完全重复的行;

2、ROW_NUMBER() OVER(order by "c_WhsDesc" asc):窗口函数,按c_WhsDesc升序为每一行生成连续不重复的行号,别名rowNumber;

3、查询字段:返回行号、仓库描述c_WhsDesc、托盘类型c_PalletType;

4、数据源:从表AA_RawMaterialM中查询;

5、最终排序:整体结果按c_WhsDesc升序排列。

二、PostgreSQL(PG)兼容版 SQL

原语句语法本身和 PG 高度兼容 ,仅需优化窗口函数与 DISTINCT 的执行顺序(PG 中直接混用会导致行号错乱),这是最关键的适配点:

sql 复制代码
-- PostgreSQL 标准语法(推荐,结果准确、性能最优)

SELECT

      ROW_NUMBER() OVER(ORDER BY t."c_WhsDesc" ASC) AS "rowNumber",    t."c_WhsDesc",

    t."c_PalletType"

FROM (   

-- 内层先做去重+排序,保证数据纯净

    SELECT DISTINCT "c_WhsDesc", "c_PalletType"

    FROM "AA_RawMaterialM"

    ORDER BY "c_WhsDesc" ASC

) t;

三、关键适配说明(PG vs 原 SQL)

1、核心问题

原 SQL 直接把ROW_NUMBER()和DISTINCT写在同一层,MySQL/Oracle 可执行,但PG 会先生成行号再去重,导致行号不连续、错乱;

优化方案:内层先去重排序,外层再生成行号,这是 PG 的标准最佳实践。

2、兼容点

双引号"字段名":PG 支持双引号标识字段 / 表名(区分大小写);

ROW_NUMBER()窗口函数:PG 原生支持;

DISTINCT/ORDER BY:语法完全通用。

3、简化版

如果你追求简洁,也可以用这个写法(逻辑和上面一致):

sql 复制代码
SELECT DISTINCT

    ROW_NUMBER() OVER(ORDER BY "c_WhsDesc" ASC) AS "rowNumber",    "c_WhsDesc",

    "c_PalletType"

FROM "AA_RawMaterialM"

ORDER BY "c_WhsDesc" ASC;

四、总结

1、原 SQL 功能:去重查询原料表数据,并生成连续行号;

2、PG 适配核心:先去重,后生成行号,避免行号异常;

3、推荐使用分层写法,兼容性、准确性、性能都最优。

其实上面问的时候问错了,本来想让其将PG语法修改为MySQL数据库的语法,结果要求成改为PG库了,问题是原语句本就是PG语法的SQL。

于是又让其重新改一遍,助理态度特别好,一点脾气都没有,分分钟给出改好的结果。

但修改完运行报错,于是将报错信息直接丢给豆包,质问他,你刚才生成的SQL语句报这个错,于是他又给出报错原因,及修改办法,非常好用。

相关推荐
廿一夏7 小时前
MySql存储引擎与索引
数据库·sql·mysql
lzhdim9 小时前
SQL 入门 15:SQL 事务:从 ACID 到四种常见的并发问题
数据库·sql
瀚高PG实验室9 小时前
瀚高企业版V9.1.1在pg_restore还原备份文件时提示extract函数语法问题
数据库·瀚高数据库
TDengine (老段)10 小时前
TDengine Tag 设计哲学与 Schema 变更机制
大数据·数据库·物联网·时序数据库·iot·tdengine·涛思数据
YOU OU11 小时前
Spring IoC&DI
java·数据库·spring
Muscleheng11 小时前
Navicat连接postgresql时出现‘datlastsysoid does not exist‘报错
数据库·postgresql
罗超驿12 小时前
18.事务的隔离性和隔离级别:MySQL面试高频考点全解析
数据库·mysql·面试
jran-12 小时前
Redis 命令
数据库·redis·缓存
小江的记录本13 小时前
【Java基础】Java 8-21新特性:JDK21 LTS:虚拟线程、模式匹配switch、结构化并发、序列集合(附《思维导图》+《面试高频考点清单》)
java·数据库·python·mysql·spring·面试·maven
June`13 小时前
多线程redis下如何解决aof重写和rdb持久化的数据一致性问题
数据库·redis·缓存