1 / 15

Introduction to LINQ

Introduction to LINQ. Language-Integrated Query. Queries. A query is an expression that retrieves data from a data source. Queries are usually expressed in a specialized query language.

rollin
Download Presentation

Introduction to LINQ

An Image/Link below is provided (as is) to download presentation Download Policy: Content on the Website is provided to you AS IS for your information and personal use and may not be sold / licensed / shared on other websites without getting consent from its author. Content is provided to you AS IS for your information and personal use only. Download presentation by click this link. While downloading, if for some reason you are not able to download a presentation, the publisher may have deleted the file from their server. During download, if you can't get a presentation, the file might be deleted by the publisher.

E N D

Presentation Transcript


  1. Introduction to LINQ Language-Integrated Query

  2. Queries • A query is an expression that retrieves data from a data source. • Queries are usually expressed in a specialized query language. • Developers have had to learn a new query language for each type of data source or data format that they support. • LINQ offers a consistent model for working with data across various kinds of data sources and formats. • In a LINQ query, you are always working with objects. • You use the same basic coding patterns to query and transform data in XML documents, SQL databases, ADO.NET Datasets, .NET collections, and any other format for which a LINQ provider is available.

  3. Three Parts of a LINQ Query Operation • Obtain the data source • Create the query • Execute the query

  4. static void Main() { // Data source. int[] scores = { 90, 71, 82, 93, 75, 82 }; // Query Expression. IEnumerable<int> scoreQuery = //query variable from score in scores //required where score > 80 // optional orderby score descending // optional select score; //must end with select or group // Execute the query to produce the results foreach (inttestScore in scoreQuery) { Console.WriteLine(testScore); } } // Outputs: 93 90 82 82

  5. LINQ Data Source • A LINQ data source is any object that supports the generic IEnmerable<T> interface, or an interface that inherits from it. • With LINQ to SQL, first create an object-relational mapping at design time • Write your queries against the objects • at run-time LINQ to SQL handles the communication with the database.

  6. LINQ Query • The query specifies what information to retrieve from the data source or sources. • Optionally, a query also specifies how that information should be sorted, grouped, and shaped before it is returned. • A query is stored in a query variable and initialized with a query expression. • To make it easier to write queries, C# has introduced new query syntax.

  7. LINQ Query • In a LINQ query, the first step is to specify the data source. • In C# as in most programming languages a variable must be declared before it can be used. • In a LINQ query, the from clause comes first in order to introduce the data source (customers) and the range variable (cust). // Use of var is optional here and in all queries. //queryAllCustomers is an IEnumerable<Customer> varqueryAllCustomers = from cust in customers select cust;

  8. Filtering • The most common query operation is to apply a filter in the form of a Boolean expression. • The filter causes the query to return only those elements for which the expression is true. //queryLondonCustomersis an IEnumerable<Customer> varqueryLondonCustomers = from cust in customers where cust.City == "London" select cust;

  9. Filtering • You can use the familiar C# logical AND and OR operators to apply as many filter expressions as necessary in the where clause. where cust.City=="London" && cust.Name == "Devon" where cust.City == "London" || cust.City == "Paris"

  10. Ordering • Sort the returned data using the orderby clause varqueryLondonCustomers3 = from cust in customers where cust.City == "London" orderbycust.Name ascending select cust;

  11. select Clause • A simple select clause just produces a sequence of the same type of objects as the objects that are contained in the data source. IEnumerable<Country> sortedQuery = from country in countries orderbycountry.Area select country;

  12. Selecting • The select clause can also be used to transform source data into sequences of new types. This transformation is also called a projection //queryAllCustomers is an IEnumerable<StoreCustomer> varqueryAllCustomers = from c in customers select new StoreCustomer { Name = c.Name, Address = c.Address, Email = c.Email, Phone = c.Phone };

  13. Joining • In LINQ the join clause always works against object collections instead of database tables directly. varqueryCustomersDistributors= from cust in customers join dist in distributors on cust.City equals dist.City select new CustomerDistributor { CustomerName= cust.Name, DistributorName= dist.Name };

  14. Query Execution //convert LINQ Query results to a list of ProductTypeobjects IList<DataContracts.ProductType> productTypes = etTypes.ToList(); //assign first element in a sequence, //or a default value if the sequence contains no elements ProductTypesomeProductType= etType.FirstOrDefault();

  15. Query Syntax and Method Syntax //Query syntax IEnumerable<City> queryMajorCities = from city in cities where city.Population > 100000 select city; // Method-based syntax IEnumerable<City> queryMajorCities2 = cities.Where(c => c.Population > 100000);

More Related