Vanna Text2SQL数据库平权

最近都在面试,拿了些offer保底,别人寒假的时候我努力,竞争的人不多,各位老板也可以投投试试。

开年的股市就是个笑话,明年春招难搞!自己还是很想去抖音、拼多多等大厂的,走传统前/后端跟一群大佬去厮杀少量的HC,还不如另辟蹊径...

最近看牛客、Boss直聘上AIGC前端方向,有些大厂的招聘信息。这可能是条去大厂发财的好路子,开搞!

前言

前端搞全栈,复杂SQL是个难点。我之前写过一篇LangChain实战: 老喻干货店TextToSql,今天跟大家分享Vanna, 一款基于RAG的自然语言生成SQL的工具。

Vanna

激动的心,颤抖的手,点击右上角Get Start for Free,试用一下。经过邮箱认证后,我们会拿到如下的API:

我们来看下官方给的Demo:

python 复制代码
# 安装vanna 
!pip install vanna
# vanna.remote 提供访问远程的数据库,这个很实用
from vanna.remote import VannaDefault
# 返回vn 实例  
vn = VannaDefault(model='chinook', api_key='****')
# 连接数据库  
vn.connect_to_sqlite('https://vanna.ai/Chinook.sqlite')
# 销售额排名前十的艺术家是?
vn.ask('What are the top 10 artists by sales?')
# 执行
from vanna.flask import VannaFlaskApp
VannaFlaskApp(vn).run()

从代码看,vanna还是很强大的。首先,它有VannaFlaskApp,把Text2SQL提升到App的高度,看来我们使用vanna给全公司搭个TextToSql应用很方便了。从名字看,VannaFlaskApp,底层以来Flask。其次,远程连接数据库的能力非常nice,实例化VannaDefault,传递给它模型和api_key,就可以连接远程数据库。最后,实例上的ask方法可以进行自然语言数据查询。这比我之前看在的Text2SQL 在工程化完备程度上好太多了。

您先按这个地址将sqlite数据库下载下来,并使用vscode(sqlite viewer插件)打开。  销售额排名前十的艺术家这个查询关联Artist、Album、Track、InvoiceLine三个表。截图我就不一一给出,大家可以自己看。

sql 复制代码
# 生成的SQL, 挺复杂的
SELECT a.ArtistId, a.Name, SUM(il.Quantity) AS TotalSales
FROM Artist a
INNER JOIN Album al ON a.ArtistId = al.ArtistId
INNER JOIN Track t ON al.AlbumId = t.AlbumId
INNER JOIN InvoiceLine il ON t.TrackId = il.TrackId
GROUP BY a.ArtistId, a.Name
ORDER BY TotalSales DESC
LIMIT 10;
yaml 复制代码
# 查询结果
 ArtistId                     Name  TotalSales
0        90              Iron Maiden         140
1       150                       U2         107
2        50                Metallica          91
3        22             Led Zeppelin          87
4       113  Os Paralamas Do Sucesso          45
5        58              Deep Purple          44
6        82            Faith No More          42
7       149                     Lost          41
8        81             Eric Clapton          40
9       124                   R.E.M.          39

Artist 表是艺术家表,有ArtistId 和 Name(艺术家名字)两个字段。除此之外我们还需要排名取前十位,并计算销售额。

InvoiceLine是销售记录表,invoice是发票的意思。InvoiceLine里有一个TrackId字段指向Track表。

Track表包含AlbumId字段,指向Album 艺术品表。

找到了AlbumId, 通过Album表就可以找到ArtistId

天啊,这个表分的真够细!但这才是真正线上中大型项目的真实情况。而我们要做的Text2SQL 企业版,要在技术、运营、小编、用户等都可以用起来,Vanna展示了它的强大!

AI工具更新换代很快,很开心今天与Vanna的相见。就到这里,休息一下!下次再与大家一起深入越野Vanna的领地越野。

总结

  • Vanna官网
  • Vanna 基于LLM,基于RAG
  • 数据库不再是技术的专利,Text2SQL语义化查询带来数据库平权!Vanna好像可以投入生产。

参考资料

相关推荐
LLSU131 分钟前
聚星文社AI软件小说推文软件
人工智能
JackieZhengChina4 分钟前
吴泳铭:AI最大的想象力不在手机屏幕,而是改变物理世界
人工智能·智能手机
ShuQiHere5 分钟前
【ShuQiHere】 探索数据挖掘的世界:从概念到应用
人工智能·数据挖掘
嵌入式杂谈6 分钟前
OpenCV计算机视觉:探索图片处理的多种操作
人工智能·opencv·计算机视觉
时光追逐者7 分钟前
分享6个.NET开源的AI和LLM相关项目框架
人工智能·microsoft·ai·c#·.net·.netcore
东隆科技7 分钟前
PicoQuant公司:探索铜铟镓硒(CIGS)太阳能电池技术,引领绿色能源革新
人工智能·能源
DisonTangor19 分钟前
上海AI气象大模型提前6天预测“贝碧嘉”台风登陆浦东 今年已多次精准预测
人工智能
人工智能培训咨询叶梓36 分钟前
生成式人工智能在无人机群中的应用、挑战和机遇
人工智能·语言模型·自然语言处理·aigc·无人机·多模态·生成式人工智能
羊小猪~~1 小时前
深度学习基础案例5--VGG16人脸识别(体验学习的痛苦与乐趣)
人工智能·python·深度学习·学习·算法·机器学习·cnn
Zhangci]1 小时前
OpenCv(一)
人工智能·opencv·计算机视觉