linq4j java8_蓝色星空

Implement and test the methods allowing queries on Enumerables. The methods

are specified in ExtendedEnumerable, DefaultEnumerable calls the

implementations in Extensions. We'll do these in tranches. Each time you

implement a method, add a test similar to Linq4jTest.testWhere.

Try to refactor out some helper (named inner) classes, rather than creating

2 or 3 anonymous classes per method.

Third tranche: implement groupBy for Enumerable.

Fourth tranche: implement any, all, aggregate, sum, min, max, average

for Enumerable.

Sixth tranche: implement union, intersect, except, distinct methods

for Enumerable.

Seventh tranche: first, last, defaultIfEmpty, elementAtOrDefault,

firstOrDefault, lastOrDefault for Enumerable. May need to add a class

parameter so that we can generate the right default value.

Eighth tranche: implement orderBy, reverse for Enumerable.

Ninth tranche: implement methods that require EqualityComparer.

Last tranche: all remaining methods for Enumerable.

Parser support. Either modify a Java parser (e.g. OpenJDK), or write a

pre-processor. Generate Java code that includes expression trees.

Port Enumerable and Queryable to Scala. Change classes (in particular,

collections and function types) so that user code is looks like concise,

native Scala. Share as much of the back-end as possible with linq4j, but

don't compromise the Scala look-and-feel of the front-end. Use adapters

(and sacrifice a bit of performance) if it helps.

Write a simple LINQ-to-SQL provider. This would generate SQL and get data

from JDBC. It's a prototype, demonstrating that we can connect the dots.

Plan to throw it away.

In the prototype LINQ-to-SQL provider, write a simple rule to recognize a

select list and where clause and push them down to SQL.

Test Scala front-end against LINQ-to-SQL provider.

A better provider using a planner framework.

JDBC driver on top of linq4j (not necessarily on top of the

Queryable/Expression object model; more likely on the query model that this

translates to).

Use planner framework to build back-ends to non-SQL data sources (e.g.

MongoDB, Hadoop, text files).

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
注:下文中的 *** 代表文件名中的组件名称。 # 包含: 中文-英文对照文档:【***-javadoc-API文档-中文(简体)-英语-对照版.zip】 jar包下载地址:【***.jar下载地址(官方地址+国内镜像地址).txt】 Maven依赖:【***.jar Maven依赖信息(可用于项目pom.xml).txt】 Gradle依赖:【***.jar Gradle依赖信息(可用于项目build.gradle).txt】 源代码下载地址:【***-sources.jar下载地址(官方地址+国内镜像地址).txt】 # 本文件关键字: 中文-英文对照文档,中英对照文档,java,jar包,Maven,第三方jar包,组件,开源组件,第三方组件,Gradle,中文API文档,手册,开发手册,使用手册,参考手册 # 使用方法: 解压 【***.jar中文文档.zip】,再解压其中的 【***-javadoc-API文档-中文(简体)版.zip】,双击 【index.html】 文件,即可用浏览器打开、进行查看。 # 特殊说明: ·本文档为人性化翻译,精心制作,请放心使用。 ·本文档为双语同时展示,一行原文、一行译文,可逐行对照,避免了原文/译文来回切换的麻烦; ·有原文可参照,不再担心翻译偏差误导; ·边学技术、边学英语。 ·只翻译了该翻译的内容,如:注释、说明、描述、用法讲解 等; ·不该翻译的内容保持原样,如:类名、方法名、包名、类型、关键字、代码 等。 # 温馨提示: (1)为了防止解压后路径太长导致浏览器无法打开,推荐在解压时选择“解压到当前文件夹”(放心,自带文件夹,文件不会散落一地); (2)有时,一套Java组件会有多个jar,所以在下载前,请仔细阅读本篇描述,以确保这就是你需要的文件;

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值