BT

如何利用碎片时间提升技术认知与能力? 点击获取答案

Lovefield:谷歌开发的类似SQL的查询引擎

| 作者 Abel Avram 关注 10 他的粉丝 ,译者 谢丽 关注 11 他的粉丝 发布于 2014年11月28日. 估计阅读时间: 3 分钟 | AICon 关注机器学习、计算机视觉、NLP、自动驾驶等20+AI热点技术和最新落地成功案例。

Lovefield是一个JavaScript库。它为希望利用关系型数据库优点的Web开发人员提供了一个类似SQL的查询引擎。

早在2010年,Chrome 4就包含了WebSQL Database API,尝试向Web开发人员提供一种SQL数据存储。Chrome的持久化存储是SQLite。Safari开发人员也致力于支持该API。问题在于,W3C停止了该API规范的制定工作,因为“所有感兴趣的实现者都使用了相同的SQL后端(SQLite),但是,他们需要多种独立的实现才能沿着标准化的道路继续前进。”W3C继续致力于Web StorageIndexed Database API方面的工作,两者都为主流浏览器所广泛采用,其中前者是一个简单的键值存储解决方案。

Lovefield是一个跨浏览器的类似SQL的查询引擎。现在,谷歌希望通过它再次为开发人员提供关系型数据库。Lovefield并不包含SQL查询分析器,但它以JavaScript库的形式提供对SQL 2003的一个有限子集的支持。开发人员可以使用JavaScript函数调用查询数据库。该引擎使用IndexedDB作为持久化存储,但为便于测试,它也可以运行在基于内存的临时存储上。Demetrios Papadopoulos是Chrome团队的一名开发人员。据他介绍,Lovefield适用于对存储需求较小的应用程序:数据集当前限制在2GB,数据在5万行之内时,引擎性能尚有保证,但将来其性能还会提升。

Lovefield支持:

  • 查询:select、insert、update、delete
  • 事务
  • 完整性约束检查
  • 聚合函数(count、min、max、sum、avg、stddev、distinct)
  • 多表关联
  • 模式升级
  • Promises
  • 其设计考虑了低端设备
  • 可以在Chrome、Firefox和IE 10上运行,并提供了必要的Polyfill。在有一种“可用的”IndexedDB实现之前,对Safari的支持暂时不会进行。

有些SQL功能将不会实现,如游标、视图、子查询和触发器。

虽然没有提供详细信息,但谷歌提到,他们计划未来将这项技术标准化,而且他们已经把它用在了Chrome应用、Google Play Movies&TV中。

Lovefield目前只支持JavaScript,但将来它可能会增加对其它语言的支持。Dart是一种可能。

相关资源:Lovefield规范设计GitHub库

查看英文原文:Lovefield: An SQL-like Query Engine by Google

评价本文

专业度
风格

您好,朋友!

您需要 注册一个InfoQ账号 或者 才能进行评论。在您完成注册后还需要进行一些设置。

获得来自InfoQ的更多体验。

告诉我们您的想法

允许的HTML标签: a,b,br,blockquote,i,li,pre,u,ul,p

当有人回复此评论时请E-mail通知我
社区评论

允许的HTML标签: a,b,br,blockquote,i,li,pre,u,ul,p

当有人回复此评论时请E-mail通知我

允许的HTML标签: a,b,br,blockquote,i,li,pre,u,ul,p

当有人回复此评论时请E-mail通知我

讨论

登陆InfoQ,与你最关心的话题互动。


找回密码....

Follow

关注你最喜爱的话题和作者

快速浏览网站内你所感兴趣话题的精选内容。

Like

内容自由定制

选择想要阅读的主题和喜爱的作者定制自己的新闻源。

Notifications

获取更新

设置通知机制以获取内容更新对您而言是否重要

BT