Show/Hide Toolbars

XSharp

The LINQ expression rule is:

 

linqquery           :  fromClause queryBody
                   ;
 
fromClause          : FROM identifier (AS typeName)? IN expression
                   ;
 
queryBody           : (queryBodyClause)* selectOrGroupclause (queryContinuation)?
                   ;
 
queryBodyClause     : fromClause                                                                                        
                   | LET identifier ASSIGN_OP expression                                                              
                   | WHERE expression                                                                                  
                   | JOIN identifier (AS typeName)? IN expression ON expression EQUALS expression joinIntoClause?      
                   | ORDERBY ordering (, ordering)*                          
                   ;
 
joinIntoClause      : INTO identifier
                   ;
 
ordering            : expression (ASCENDING|DESCENDING)?
                   ;
 
selectOrGroupclause : SELECT expression                        
                   | GROUP expression BY expression            
                   ;
 
queryContinuation   : INTO identifier queryBody

An example of a LINQ Query:

  VAR oAll := FROM D IN oDev  ;
          JOIN C IN oC ON D:Country EQUALS C:Name   ;
          ORDERBY D:LastName  ;
          SELECT CLASS {D:Name, D:Country, C:Region}      

In this example you will see

fromclause:                          FROM D in oDev
querybody 1:                  JOIN C IN oC ON D:Country EQUALS C:Name
querybody 2:                  ORDERBY D:LastName
selectOrGroupClause:        SELECT CLASS {...}

Other examples can be found in the LINQ Example topic.