You are viewing a plain text version of this content. The canonical link for it is here.
Posted to notifications@groovy.apache.org by "Daniel Sun (JIRA)" <ji...@apache.org> on 2019/08/10 16:51:00 UTC

[jira] [Updated] (GROOVY-8258) Create a LINQ-like DSL

     [ https://issues.apache.org/jira/browse/GROOVY-8258?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel ]

Daniel Sun updated GROOVY-8258:
-------------------------------
    Description: 
h4. 1.1
{code:java}
from p of persons
where p.age > 15 && p.age <= 35
select p.name
{code}


  was:
Reference: https://code.msdn.microsoft.com/101-LINQ-Samples-3fb9811b/view/SamplePack#content

 

*Pojos:*
{code:java}
class Category {
   String name
   List<Article> articles
}

class Article {
  String name
  Integer voteCount
  String categoryName
}
{code}
*Example1:*
{code:java}
linq { // return an Iterator<Map<String, Object>>
    from c of categories
    join a of articles on a.categoryName == c.name // join
    where c.name == 'Groovy'
    orderBy a.voteCount desc // order by
    limit 100 offset 50 // pagination
    select { // create a map, its keys: articleName, voteNum, categoryName
        articleName = a.name
        a.voteCount 
        categoryName = c.name
    }
}
{code}
*Example2:*
{code:java}
linq { // return an Iterator<Map<String, Object>>
    from c of categories
    join a of {
        from tempA of articles
        where tempA.voteCount > 10
        select tempA
    } on a.categoryName == c.name // join
    where c.name == 'Groovy'
    orderBy a.voteCount desc // order by
    limit 100 offset 50 // pagination
    select { // create a map, its keys: articleName, voteNum, categoryName
        articleName = a.name
        a.voteCount 
        categoryName = c.name
    }
}
{code}
*Example3:*
{code:java}
linq { // return an Iterator<Article>
    from c of categories
    from a of c.articles  // another join
    where c.name == 'Groovy'
    orderBy a.voteCount desc // order by
    select Article { // create an Article instance
        a.name
        a.voteCount 
        categoryName = c.name
    }
}
{code}
*TO BE CONTINUED...*


> Create a LINQ-like DSL
> ----------------------
>
>                 Key: GROOVY-8258
>                 URL: https://issues.apache.org/jira/browse/GROOVY-8258
>             Project: Groovy
>          Issue Type: Improvement
>            Reporter: Daniel Sun
>            Priority: Major
>
> h4. 1.1
> {code:java}
> from p of persons
> where p.age > 15 && p.age <= 35
> select p.name
> {code}



--
This message was sent by Atlassian JIRA
(v7.6.14#76016)