Text2sql的一些技巧

最近看到了一篇关于text2sql的文章,以及一些论文。对使用模型做text2sql给了一些不错的建议。

参考文章:24年大模型潜力方向:大浪淘沙后的Text-to-SQL和Agent - 知乎

论文:https://arxiv.org/pdf/2403.09732.pdf

关于模型的建议

模型的温度为0,减少text2sql的幻觉问题。

多个模型一起使用,使用交叉一致性,不要过于依赖一个模型。

构建prompt的建议

表中字段取值问题,例如性别这个字段,有的表可能存"男"和"女",有的表可能存 "M"和"F",甚至有的表会存"0"和"1"。所以对于有枚举值的字段来说,最好能够列出来示例字段。数据表和样例数据(随机取三行数据)

text2sql中,few-shot非常有用。应该生成一些常见的sql示例。这些案例在prompt中应该是动态选择的(针对不同的表)。关于生成常见的sql,可以考虑使用模型,来生成一些sql示例。

few-shot 示例

告诉模型,我们的表字段,并给出了一些示例数据以及表的外键

给模型的few-shot 对生成正确的sql的影响非常大。论文中提到的是动态的选择样例,

根据问题相似相匹配,用问题,召回几个相似的文本(这里需要提前根据表生成一些案例)。

相关推荐
yubinCloud7 天前
【Text2SQL 论文】MCS-SQL:利用多样 prompts + 多项选择来做 Text2SQL
数据库·语言模型·自然语言处理·prompt·text2sql
yubinCloud19 天前
【Text2SQL 论文】CHESS:利用上下文来合成 SQL 的 pipeline
数据库·人工智能·深度学习·语言模型·自然语言处理·text2sql
yubinCloud22 天前
【Text2SQL 论文】C3:使用 ChatGPT 实现 zero-shot Text2SQL
人工智能·算法·语言模型·自然语言处理·chatgpt·text2sql
yubinCloud23 天前
【Text2SQL 论文】CodeS:Text2SQL 领域的开源语言模型
人工智能·深度学习·语言模型·自然语言处理·text2sql
yubinCloud1 个月前
【Text2SQL 论文】How to prompt LLMs for Text2SQL
人工智能·深度学习·语言模型·自然语言处理·prompt·text2sql
yubinCloud1 个月前
【Text2SQL 论文】PET-SQL:用 Cross-Consistency 的 prompt 增强的两阶段 Text2SQL 框架
数据库·人工智能·算法·自然语言处理·text2sql
yubinCloud1 个月前
【Text2SQL 论文】DIN-SQL:分解任务 + 自我纠正 + in-context 让 LLM 完成 Text2SQL
人工智能·深度学习·语言模型·自然语言处理·text2sql
yubinCloud1 个月前
【Text2SQL 论文】DBCopilot:将 NL 查询扩展到大规模数据库
数据库·人工智能·算法·语言模型·自然语言处理·text2sql
yubinCloud1 个月前
【Text2SQL 论文】T5-SR:使用 T5 生成中间表示来得到 SQL
人工智能·sql·深度学习·语言模型·自然语言处理·text2sql
baker_zhuang1 个月前
使用vanna实现Text2SQL
数据库·text2sql·vanna