趣文网,分享全网好句子、好文章!

大大降低AI门槛!SQLFlow开源 使用SQL语句实现人工智能应用

时间:2023-10-06 02:10:01

相关推荐

大大降低AI门槛!SQLFlow开源 使用SQL语句实现人工智能应用

最近,蚂蚁正式了开源其机器学习工具SQLFlow。SQLFlow=SQL引擎+AI引擎。其抽象出端到端从数据到模型的研发过程,配合底层的引擎及自动优化,让具备基础SQL知识的技术人员,也能轻松完成大部分的人工智能工作,如机器学习、模型训练和预测等。用户仅需几行SQL代码就能描述整个应用或者产品背后的数据流和 AI 构造。

为何选择SQL

SQL是一种典型的描述意图,而不描述过程的编程语言。什么意思呢?比如我们需要join两张表的数据,如何采用java、c或者python等,我们需要调用相应的函数或包进行具体的连接操作,比如写循环和构造hash map描述如何join两张表。但是如果使用SQL的话,我们并不用关心这些,只要告诉写出我们想干嘛就可以了。

另外,SQL的语法和语句量并不多,因此写起来难度也低很多。

如何利用SQL实现机器学习

SQLFlow通过对基本的SQL语法进行扩展来实现AI功能。如在SELECT语句后面,加上一个扩展语法的 TRAIN 从句,即可实现 AI 模型的训练。或者加上一个 PREDICT 从句即可实现用现有模型做预测。此外,SQLFlow也提供一些基本功能,可以供各种 submitter 翻译插件使用,用来根据数据的特点,推导如何自动地把数据转换成 features,这样用户就不需要在 TRAIN 从句里描述这个转换。

将SQL和AI连接在一起的想法其实也并不是蚂蚁SQLFlow的首创,早在2018年谷歌就发布了 BigQueryML,让数据科学家和分析师只用 SQL 语言就可以实现流行的机器学习功能并执行预测分析。微软基于 SQL Server 的 AI 扩展,以及 Teradata 的 SQL for DL 同样旨在连接 SQL 和 AI,让人工智能的应用变得像 SQL 一样简单。不过,以上这些都不是开源项目,而蚂蚁要做的就是开源。

问题

目前,SQLFlow还很初级,还存在很多的问题,如语法解析问题,SQLFlow 目前已经对接 MySQL,正在对接 Hive 和 阿里云上的 MaxCompute,将来还希望能对接更多公司正在使用的 SQL 引擎。

SQLFlow目前依赖 TensorFlow 等底层引擎来实现训练和预测,但TensorFlow 原生支持分布式训练,但不支持容错,一个进程挂了,整个作业就挂了。而PyTorch、XGBoost、LibLinear 这些 AI 引擎的分布式计算能力也都有一些问题,因此,未来的路还很遥远。

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。
显示评论内容(3)
  1. 巭孬嫑莪2024-02-25 13:52巭孬嫑莪[山西省网友]150.242.28.73
    听SQLFlow可以用SQL语句实现人工智能应用感觉像是打开了新世界大门!这个工具出现将让AI开发变得更加简单易懂。]
    顶4踩0
  2. 为你而战  ❤SJQ❤2024-01-09 01:58为你而战 ❤SJQ❤[上海市网友]110.76.15.168
    SQLFlow真是太棒了!以前我只会写SQL查询现在居可以用它构建人工智能应用简直惊喜!这将为许多开发者带新机会。,
    顶8踩0
  3. 浪漫树风2023-11-22 14:04浪漫树风[江苏省网友]49.233.159.32
    [大大降低AI门槛!这对于那些熟悉SQL语句人真是个福音。SQLFlow开源意味着更多人可以参与到人工智能应用开发中。,
    顶7踩0
相关阅读
3分钟短文|Laravel 获取模型查询生成的SQL语句

3分钟短文|Laravel 获取模型查询生成的SQL语句

而laravel提供了非常好的 debug 支持,只需在 env 文件内指定 debug = true ,就可以在页面打开 debug bar 用于调试

2023-05-13

mysql基础之sql语句分类及实际中的用途

mysql基础之sql语句分类及实际中的用途

显得专业你会拿到公司的Offer,显得专业客户就信服你,显得专业领导就欣赏你,反正就是各种好处,今天咱们就来讲一讲mysql专业一点的东西,提升一下逼格

2023-10-07

SQL数据库及SQL语言是什么?

SQL数据库及SQL语言是什么?

数据库是什么?之前小编在这个问题上详细讲述过详见数据库,和现实生活中的各类仓库一样,数据库就是网络上用来存放数据的地方,用户可以对这些数据进行

2023-05-08

SQL拦截器修改执行的sql语句

SQL拦截器修改执行的sql语句

简单的思路是拦截执行的sql语句 然后修改原本需要执行的sql 将新的sql语句放回Executor中执行

2023-06-09