活动回顾 | 用 SQL Chat 告别写代码的抓狂,以自然语言与数据库轻松交互

数据库
Tech Talk
SQL
GitHub
自然语言处理
0
0
对于程序员来说,通过 SQL 操作数据库是日常工作中经常会遇到的任务,算得上是一项基本技能。但即便是专业人员面对 SQL 编写任务也往往会头疼不已,更不要说在这一领域经验不足的初学者了。ChatGPT 大火之后,其辅助程序员编写代码的能力受到了很大关注。那么,类似 ChatGPT 这种能力能否用在数据库操作上,帮助程序员甚至是缺乏代码经验的普通业务人员,使用自然语言来完成过去需要 SQL 才能做的事情呢?在近日举办的亚马逊云开发者 Tech Talk 上,**Bytebase 联合创始⼈/CEO 陈天舟**就介绍了这样一款产品——基于亚马逊云科技的云服务架构,可以用自然语言与数据库交互的 **SQL Chat**。 ## **软件交互范式的演进:从命令行到 CUI** 回顾软件行业的交互范式演进史,大致上是从桌面到 Web 端,再到移动端。在上世纪70年代,用户一般通过命令后界面(CLI)与计算机交互。发展到1979年出现了 VisiCalc, VisiCalc 首次引入了表格布局交互界面,具有革命性的意义。 ![image.png](https://dev-media.amazoncloud.cn/6813b210d1964534b3697fbb000c5424_image.png "image.png") 这款软件还带火了 Apple 2 电脑,让很多个人用户开始采购这款 PC 来制作表格。之后到了1984年,苹果发布了 Macintosh,搭配键盘、鼠标并采用了 GUI 界面,这也是现代 PC 所采用的标准界面的起源。再到1993年,第一款网页浏览器 Mosaic 诞生。 ![image.png](https://dev-media.amazoncloud.cn/5fa955a46f4e47a7b1319424d3b9a7f4_image.png "image.png") 这款浏览器开启了 Web 端的时代。继续向前来到2007年,iPhone 的发布则开启了现代智能手机时代。这样来看,命令行 CLI 交互大概从70年代流行到1984年,GUI 的发展则分了三个阶段,首先是1984-1993年是桌面端,1993-2007年是 Web 端,2007年到现在则是移动端,每一次换代间隔大约13年左右。 而到了2023年的今天,ChatGPT 横空出世。ChatGPT 的交互方式可以称为 Chat User Interface (CUI)。从2007年到2023年,历经16年的等待,软件行业终于迎来了交互范式的又一场革新。 ## **数据库交互与 CUI 革命** 软件交互范式的进化自然也会影响数据库的操作方式。以 SQL 客户端这个具体场景来为例,今天的 SQL 客户端还有很多命令行的交互工具,但业内也存在很多起源于 Windows 的 GUI 工具,比如 Navicat 等。 ![image.png](https://dev-media.amazoncloud.cn/7a2e3169dcf94defa6fbf9a26483693f_image.png "image.png") 如今,基于 CUI 的全新交互方式就完全不一样了。CUI 没有大量控件组合,只有一个简单直接的输入框。用户用自然语言问数据库问题,它会神奇地写出对应的 SQL 语句同数据库交互。这种进化能让人想到谷歌诞生之前的雅虎。彼时雅虎在做黄页目录,用户通过线上黄页查找信息;之后谷歌直接推出了搜索框,一个搜索框就能找到互联网的所有内容。现在的数据库交互软件有众多复杂的控件、树、表单,而到了 CUI 时代,所有这些元素都消失了,用户只需一个对话框来输入问题,机器人就能给出回答。 ![image.png](https://dev-media.amazoncloud.cn/d123818feaff49e7a40d04e536241f59_image.png "image.png") ## **SQL Chat:用自然语言和数据库交互的全新工具** 所谓 SQL Chat,顾名思义就是用聊天的方式写 SQL,跟数据库打交道。下图是整个产品的界面。 ![image.png](https://dev-media.amazoncloud.cn/8c97c81dcdf04747a8bfbe2cdebdd74c_image.png "image.png") 例如向 SQL Chat 提问,问用户组织里面哪个部门有最多的员工,这个工具就能直接给出对应的 SQL 语句,还会解释这个语句的含义。 ![image.png](https://dev-media.amazoncloud.cn/ea02e9ea24124ebfa6359e2bd8c23973_image.png "image.png") 如果用户对结果不满意还能纠正它,可以说这个语句不是自己想要的,给出理由让它重新尝试,它会根据用户的反馈再做调整。 ![image.png](https://dev-media.amazoncloud.cn/29547563f0cd4a0e8d10ac595cf65269_image.png "image.png") ![image.png](https://dev-media.amazoncloud.cn/00c60f6d3054494fa38b007374d71c19_image.png "image.png") 它的交互方式是很自然的,就像用户在和人类对话一样。**例如,用户可以创建一个 [Amazon Aurora](https://aws.amazon.com/cn/rds/aurora/?trk=cndc-detail) 的 HR 数据库,之后先问一些基本的问题,让它回答数据库有哪些表**。SQL Chat 会知道用户对员工的薪资和职称是最感兴趣的,又知道部门和员工之间是生产关系,知道员工个人信息是个人隐私。 如果提问哪个部门的员工平均薪水最高,它不仅会给出 SQL 语句,还会解释这条 SQL 是什么操作。再来问它哪个经理手下人员最多,列出 SQL 代码,它会给出查询语句查到手下员工最多的经理。如果用户对这条查询不是那么满意,还想看一下这位经理到底有多少个员工,请机器人把他的员工数也包含在内,它就会给出修正的查询。 但目前 SQL Chat 涉及子查询的时候还是会出现一些问题,可能会报错、提示内容未指定等。这反映出它使用的模型还是有一些局限性,陈天舟表示,这类问题在未来随着调优是可以解决的。 ![image.png](https://dev-media.amazoncloud.cn/2ce8b5602f804d67945dd0bdf4f8b917_image.png "image.png") **未来,开发团队会收集一些交互数据,把这些数据进行脱敏匿名化处理后放到 [Amazon S3](https://aws.amazon.com/cn/s3/?trk=cndc-detail) 上,再把它灌到 [Amazon SageMaker](https://aws.amazon.com/cn/sagemaker/?trk=cndc-detail),在 [Amazon SageMaker](https://aws.amazon.com/cn/sagemaker/?trk=cndc-detail) 里做整个模型的训练调优**。陈天舟预计,半年后再演示新版 SQL Chat 时就能比较好地解决子查询的问题了。 SQL Chat 背后的公司叫做 Bytebase,主要做数据库管理工具。如果企业需要 Schema 的数据结构变更、数据查询,或者团队之间需要有一套标准的审批流,做数据安全治理,Bytebase 的主产品都可以满足。它主要面向团队和企业级,是开源的。SQL Chat 在 GitHub 上是完全开源的 ( https://github.com/sqlchat/sqlchat?trk=cndc-detail ), 接下来也会有很快的迭代速度。最后 SQL Chat 后期还有望支持多模态输入。 点击[**此处**](https://dev.amazoncloud.cn/activity/activityDetail?id=6438cc4ebfa87b1826191eb5&catagoryName=techTalk),查看本期 Tech Talk 视频回顾。
0
目录
关闭