Entity Framework Guide for Developers
Entity Framework Guide for Developers
• Database Developer creates tables with columns and rows in the database.
• EF Developer creates a model class for each table. The model class reflects structure of the table,
treating columns as properties.
• EF Developer calls a Query (ToList) or Non-Query (SaveChanges).
• EF converts the EF query / non-query into equivalent SQL statement.
• EF connects to database using ADO.NET internally and it executes the SQL statement at database.
• Database provides the result data in the form of DataReader.
• EF reads data from data reader and converts the data into Object or Collection.
• Developer reads and prints data from Object or Collection.
• Conceptual Model: It contains model classes created by developer. The class names / property names
may differ from the table names / column names.
• Storage Model: It contains actual table names and column names.
• Mapping: Mapping between conceptual model and storage model.
• LINQ Queries: Contains actual LINQ queries like ToList(), SaveChanges(), Where, OrderBy() etc.
• Object Services: It acts as mediator between “LINQ” and “EntityClient Data Provider”. It passes LINQ
queries to “EntityClient Data Provider”. It converts result data into objects / collections.
• EntityClient Data Provider: It acts as mediator between “Object Services” and “ADO.NET Data
Provider”. It receives LINQ queries from “Object Services” and converts LINQ Queries to equivalent SQL
Queries and passes the same SQL Queries. It also passes the result data to “Object Services”.
• ADO.NET Data Provider: It is actual ADO.NET classes such SqlConnection, SqlCommand,
SqlDataReader etc. It submits the SQL queries to Database (SQL Server). It receives the result data
from database and passes the same to EntityClient Data Provider.
• Database: Stores actual tables. It executes the actual SQL queries and send result data to ADO.NET
Data Provider.
Model Class
• Model class reflects structure of the table.
• Table is treated as a class.
• Column is treated as a property.
using System.ComponentModel.DataAnnotations;
class modelclassname
{
[Key]
public datatype propertyname { get; set; }
public datatype propertyname { get; set; }
public datatype propertyname { get; set; }
…
}
DbContext Class
• DbContext class represents a collection of DbSet's.
• DbSet is a virtual table, which represents a table. It doesn’t store any data. One DbSet represents only one table.
LINQ queries are written based on DbSet only. DbSet provides methods to retrieve, insert, update and delete data.
• The DbContext class should be child class of System.Data.Entity.DbContext class.
• The constructor of DbContext class will be called automatically when the developer creates an object for
the DbContext class. The developer should initialize the constructor in the constructor of DbContext class,
with "base" keyword.
using System.Data.Entity;
class classname : DbContext
{
public classname() : base(@"data source=servername; user id=sa;
password=123; initial catalog=databasename")
{
}
public DbSet<modelclasname> collectionname { get; set; }
public DbSet<modelclasname> collectionname { get; set; }
…
}
• Click on “Execute” button. It shows “Query executed successfully” in the status bar.
Creating Project
• Open Visual Studio 2017.
• Go to “File” – “New” – “Project”.
• "New Project" dialogbox appears. Select “.NET Framework 4.7”. Select “Visual C#”. Select “Console
App (.NET Framework)”. Type the project name “EFExample”. Type the location as “C:\mvc”. Type the
solution name as “EFExample”. Click on OK.
Installing Packages
• Go to "Tools" menu – "NuGet Package Manager" – "Package Manager Console".
• "Package Manager Console" window will be opened.
• Type the following command in "Package Manager Console" and press
Enter. install-package EntityFramework
• The following code will be automatically generated for "packages.config".
Query Operations in EF
ToList
• The ToList() method is used to select all columns and all rows of the table. It executes the query
immediately and returns corresponding data as a "collection of objects of model class".
• Syntax:DbContextclass referencevariable = new DbContextclass();
referencevariable.Dbsetname.ToList();
Where
• The Where() method is used to select all columns and specific rows of the table. It retrieves the rows that are
matching with specified condition. The Where() method receives a lambda expression as argument, which
contains an argument (temp) that represents a row of the table, checks the condition and returns true / false. If
true is returned, the row will be taken into the result; otherwise the row will not be taken into the result.
• Syntax:DbContextclass referencevariable = new DbContextclass();
Where - Example
Creating Database
• Open SQL Server Management Studio. Select “Windows Authentication”. Click on “Connect”. Ignore
this step if “company” database already exists. Click on “New Query”. Type the following code:
• Click on “Execute” button. It shows “Query executed successfully” in the status bar.
Creating Project
• Open Visual Studio 2017. Go to “File” – “New” – “Project”. "New Project" dialogbox appears. Select “.NET
Framework 4.7”. Select “Visual C#”. Select “Console App (.NET Framework)”. Type the project name
“WhereExample”. Type the location as “C:\mvc”. Type the solution name as “WhereExample”. Click on OK.
Installing Packages
• Go to "Tools" menu – "NuGet Package Manager" – "Package Manager Console". "Package Manager Console"
window will be opened. Type the following command in "Package Manager Console" and press Enter.
install-package EntityFramework
OrderBy
• The OrderBy() method is used to select sort rows based on the specified column. It performs sorting in ascending
order. The OrderBy() method receives a lambda expression as argument, which contains an argument (temp) that
represents a row of the table, that returns a column (property), based on which the data has to be sorted.
• Syntax:DbContextclass referencevariable = new DbContextclass();
OrderBy - Example
Creating Database
• Open SQL Server Management Studio. Select “Windows Authentication”. Click on “Connect”. Ignore
this step if “company” database already exists. Click on “New Query”. Type the following code:
• Click on “Execute” button. It shows “Query executed successfully” in the status bar.
Creating Project
• Open Visual Studio 2017. Go to “File” – “New” – “Project”. "New Project" dialogbox appears. Select “.NET
Framework 4.7”. Select “Visual C#”. Select “Console App (.NET Framework)”. Type the project name
“OrderByExample”. Type the location as “C:\mvc”. Type the solution name as “OrderByExample”. Click on OK.
Installing Packages
• Go to "Tools" menu – "NuGet Package Manager" – "Package Manager Console". "Package Manager Console"
window will be opened. Type the following command in "Package Manager Console" and press Enter.
install-package EntityFramework
OrderByDescending
• The OrderByDescending() method is used to select sort rows based on the specified column. It performs
sorting in descending order. The OrderByDescending() method receives a lambda expression as
argument, which contains an argument (temp) that represents a row of the table, that returns a column
(property), based on which the data has to be sorted.
• Syntax: DbContextclass referencevariable = new DbContextclass();
OrderByDescending - Example
Creating Database
• Open SQL Server Management Studio. Select “Windows Authentication”. Click on “Connect”. Ignore
this step if “company” database already exists. Click on “New Query”. Type the following code:
• Click on “Execute” button. It shows “Query executed successfully” in the status bar.
Creating Project
• Open Visual Studio 2017. Go to “File” – “New” – “Project”. "New Project" dialogbox appears.
Select “.NET Framework 4.7”. Select “Visual C#”. Select “Console App (.NET Framework)”. Type
the project name “OrderByDescendingExample”. Type the location as “C:\mvc”. Type the solution
name as “OrderByDescendingExample”. Click on OK.
Installing Packages
• Go to "Tools" menu – "NuGet Package Manager" – "Package Manager Console". "Package Manager Console"
window will be opened. Type the following command in "Package Manager Console" and press Enter.
install-package EntityFramework
ThenBy
• The ThenBy() method is used to specify secondary column name, where as OrderBy() method is used to
specify primary sorting column name. It performs sorting in ascending order. The ThenBy() method
receives a lambda expression as argument, which contains an argument (temp) that represents a row of
the table, that returns a column (property), based on which the data has to be sorted.
• Syntax:DbContextclass referencevariable = new DbContextclass();
• Click on “Execute” button. It shows “Query executed successfully” in the status bar.
Creating Project
• Open Visual Studio 2017. Go to “File” – “New” – “Project”. "New Project" dialogbox appears. Select “.NET
Framework 4.7”. Select “Visual C#”. Select “Console App (.NET Framework)”. Type the project name
“ThenByExample”. Type the location as “C:\mvc”. Type the solution name as “ThenByExample”. Click on OK.
Installing Packages
• Go to "Tools" menu – "NuGet Package Manager" – "Package Manager Console". "Package Manager Console"
window will be opened. Type the following command in "Package Manager Console" and press Enter.
install-package EntityFramework
Reverse - Example
Creating Database
• Open SQL Server Management Studio. Select “Windows Authentication”. Click on “Connect”. Ignore
this step if “company” database already exists. Click on “New Query”. Type the following code:
• Click on “Execute” button. It shows “Query executed successfully” in the status bar.
Creating Project
• Open Visual Studio 2017. Go to “File” – “New” – “Project”. "New Project" dialogbox appears. Select “.NET
Framework 4.7”. Select “Visual C#”. Select “Console App (.NET Framework)”. Type the project name
“ReverseExample”. Type the location as “C:\mvc”. Type the solution name as “ReverseExample”. Click on OK.
Installing Packages
• Go to "Tools" menu – "NuGet Package Manager" – "Package Manager Console". "Package Manager Console"
window will be opened. Type the following command in "Package Manager Console" and press Enter.
install-package EntityFramework
Code for “Program.cs”
Select
• The Select() method is used to retrieve the specified columns, instead of retrieving all columns. The
Select() method receives a lambda expression as argument, which contains an argument (temp) that
represents a row of the table, that returns a column or a set of columns that are to be retrieved.
• Syntax: DbContextclass referencevariable = new DbContextclass();
referencevariable.Dbsetname.Select(temp => temp.columnname).ToList();
referencevariable.Dbsetname.Select(temp => new { temp.columnname1, temp.columnname2, …
} ).ToList();
Select - Example
Creating Database
• Open SQL Server Management Studio. Select “Windows Authentication”. Click on “Connect”. Ignore
this step if “company” database already exists. Click on “New Query”. Type the following code:
• Click on “Execute” button. It shows “Query executed successfully” in the status bar.
Creating Project
• Open Visual Studio 2017. Go to “File” – “New” – “Project”. "New Project" dialogbox appears. Select “.NET
Framework 4.7”. Select “Visual C#”. Select “Console App (.NET Framework)”. Type the project name
“SelectExample”. Type the location as “C:\mvc”. Type the solution name as “SelectExample”. Click on OK.
Installing Packages
• Go to "Tools" menu – "NuGet Package Manager" – "Package Manager Console". "Package Manager Console"
window will be opened. Type the following command in "Package Manager Console" and press Enter.
install-package EntityFramework
Distinct
• The Distinct() method is used to select unique (non-duplicate) values of a specific column in the table. It
also sorts sorts the column in ascending order. The Distinct() method doesn't receive any argument. We
must call Select() method to select a single column, based on which you want to apply distinct.
• Syntax:DbContextclass referencevariable = new DbContextclass();
Distinct - Example
Creating Database
• Open SQL Server Management Studio. Select “Windows Authentication”. Click on “Connect”. Ignore this step
if “departmentsandemployees” database already exists. Click on “New Query”. Type the following code:
• Click on “Execute” button. It shows “Query executed successfully” in the status bar.
Creating Project
• Open Visual Studio 2017. Go to “File” – “New” – “Project”. "New Project" dialogbox appears. Select “.NET
Framework 4.7”. Select “Visual C#”. Select “Console App (.NET Framework)”. Type the project name
“DistinctExample”. Type the location as “C:\mvc”. Type the solution name as “DistinctExample”. Click on OK.
Installing Packages
• Go to "Tools" menu – "NuGet Package Manager" – "Package Manager Console". "Package Manager Console"
window will be opened. Type the following command in "Package Manager Console" and press Enter.
install-package EntityFramework
GroupBy
• The GroupBy() method is used to group-up the rows based on a specific column in the table. It splits rows into
groups; the collection of groups is represented as IQueryable<IGrouping<keydatatype, modelclassname>> type; each
group is represented as IGrouping<keydatatype, modelclassname>. Each group contains a key with a group of rows.
The GroupBy() method receives a lambda expression as argument, which contains an argument (temp) that
represents a row of the table, that returns a column based on which grouping is to be applied.
• Syntax:DbContextclass referencevariable = new DbContextclass();
GroupBy - Example
Creating Database
• Open SQL Server Management Studio. Select “Windows Authentication”. Click on “Connect”. Ignore this step
if “departmentsandemployees” database already exists. Click on “New Query”. Type the following code:
• Click on “Execute” button. It shows “Query executed successfully” in the status bar.
Creating Project
• Open Visual Studio 2017. Go to “File” – “New” – “Project”. "New Project" dialogbox appears. Select “.NET
Framework 4.7”. Select “Visual C#”. Select “Console App (.NET Framework)”. Type the project name
“GroupByExample”. Type the location as “C:\mvc”. Type the solution name as “GroupByExample”. Click on OK.
Installing Packages
• Go to "Tools" menu – "NuGet Package Manager" – "Package Manager Console". "Package Manager Console"
window will be opened. Type the following command in "Package Manager Console" and press Enter.
install-package EntityFramework
Concat
• The Concat() method is used to concatenate two lists of same model class, into a single list. It attaches
the second list at the end of first list. The Concat() method receives the second list as argument
• Syntax:DbContextclass referencevariable = new DbContextclass();
List<modelclassname> firstlist = referencevariable.Dbsetname.ToList();
List<modelclassname> secondlist = referencevariable.Dbsetname.ToList();
Concat - Example
Creating Database
• Open SQL Server Management Studio. Select “Windows Authentication”. Click on “Connect”. Ignore this step
if “departmentsandemployees” database already exists. Click on “New Query”. Type the following code:
• Click on “Execute” button. It shows “Query executed successfully” in the status bar.
Creating Project
• Open Visual Studio 2017. Go to “File” – “New” – “Project”. "New Project" dialogbox appears. Select “.NET
Framework 4.7”. Select “Visual C#”. Select “Console App (.NET Framework)”. Type the project name
“ConcatExample”. Type the location as “C:\mvc”. Type the solution name as “ConcatExample”. Click on OK.
Installing Packages
• Go to "Tools" menu – "NuGet Package Manager" – "Package Manager Console". "Package Manager Console"
window will be opened. Type the following command in "Package Manager Console" and press Enter.
install-package EntityFramework
Union
• The Union() method is used to combines two lists of same model class, into a single list. It removes
duplicate rows, if any. The Union() method receives the second list as argument.
• Syntax:DbContextclass referencevariable = new DbContextclass();
List<modelclassname> firstlist = referencevariable.Dbsetname.ToList();
List<modelclassname> secondlist = referencevariable.Dbsetname.ToList();
List<modelclassname> finalist = firstlist.Union(secondlist).ToList();
Union - Example
Creating Database
• Open SQL Server Management Studio. Select “Windows Authentication”. Click on “Connect”. Ignore this step
if “departmentsandemployees” database already exists. Click on “New Query”. Type the following code:
• Click on “Execute” button. It shows “Query executed successfully” in the status bar.
Creating Project
• Open Visual Studio 2017. Go to “File” – “New” – “Project”. "New Project" dialogbox appears. Select “.NET
Framework 4.7”. Select “Visual C#”. Select “Console App (.NET Framework)”. Type the project name
“UnionExample”. Type the location as “C:\mvc”. Type the solution name as “UnionExample”. Click on OK.
Installing Packages
• Go to "Tools" menu – "NuGet Package Manager" – "Package Manager Console". "Package Manager Console"
window will be opened. Type the following command in "Package Manager Console" and press Enter.
install-package EntityFramework
Intersect
• The Intersect() method is used to combines two lists of same model class, into a single list. It only selects
only common (duplicate) rows, if any. The Intersect() method receives the second list as argument.
• Syntax:DbContextclass referencevariable = new DbContextclass();
List<modelclassname> firstlist = referencevariable.Dbsetname.ToList();
List<modelclassname> secondlist = referencevariable.Dbsetname.ToList();
List<modelclassname> finalist = firstlist.Intersect(secondlist).ToList();
Intersect - Example
Creating Database
• Open SQL Server Management Studio. Select “Windows Authentication”. Click on “Connect”. Ignore this step
if “departmentsandemployees” database already exists. Click on “New Query”. Type the following code:
• Click on “Execute” button. It shows “Query executed successfully” in the status bar.
Creating Project
• Open Visual Studio 2017. Go to “File” – “New” – “Project”. "New Project" dialogbox appears. Select “.NET
Framework 4.7”. Select “Visual C#”. Select “Console App (.NET Framework)”. Type the project name
“IntersectExample”. Type the location as “C:\mvc”. Type the solution name as “IntersectExample”. Click on OK.
Installing Packages
• Go to "Tools" menu – "NuGet Package Manager" – "Package Manager Console". "Package Manager Console"
window will be opened. Type the following command in "Package Manager Console" and press Enter.
install-package EntityFramework
Except
• The Except() method is used to select all rows of the first line, which are not present in the second list.
Except - Example
Creating Database
• Open SQL Server Management Studio. Select “Windows Authentication”. Click on “Connect”. Ignore this step
if “departmentsandemployees” database already exists. Click on “New Query”. Type the following code:
• Click on “Execute” button. It shows “Query executed successfully” in the status bar.
Creating Project
• Open Visual Studio 2017. Go to “File” – “New” – “Project”. "New Project" dialogbox appears. Select “.NET
Framework 4.7”. Select “Visual C#”. Select “Console App (.NET Framework)”. Type the project name
“ExceptExample”. Type the location as “C:\mvc”. Type the solution name as “ExceptExample”. Click on OK.
Installing Packages
• Go to "Tools" menu – "NuGet Package Manager" – "Package Manager Console". "Package Manager Console"
window will be opened. Type the following command in "Package Manager Console" and press Enter.
install-package EntityFramework
Code for “Program.cs”
Compile the Project
• Go to "Build" menu – click on "Build Solution" (or) Press "Ctrl+Shift+B". The project will be compiled.
Skip
• The Skip() method is used to skip the specified no. of rows and select the remaining rows. The Skip()
method receives the no. of rows as argument.
• Syntax:DbContextclass referencevariable = new DbContextclass();
referencevariable.Dbsetname.Skip(number of rows);
Skip - Example
Creating Database
• Open SQL Server Management Studio. Select “Windows Authentication”. Click on “Connect”. Ignore
this step if “company” database already exists. Click on “New Query”. Type the following code:
• Click on “Execute” button. It shows “Query executed successfully” in the status bar.
Creating Project
• Open Visual Studio 2017. Go to “File” – “New” – “Project”. "New Project" dialogbox appears. Select “.NET
Framework 4.7”. Select “Visual C#”. Select “Console App (.NET Framework)”. Type the project name
“SkipExample”. Type the location as “C:\mvc”. Type the solution name as “SkipExample”. Click on OK.
Installing Packages
• Go to "Tools" menu – "NuGet Package Manager" – "Package Manager Console". "Package Manager Console"
window will be opened. Type the following command in "Package Manager Console" and press Enter.
install-package EntityFramework
Take
• The Take() method is used to take (select) the specified no. of rows from the beginning of the table. The
Take() method receives the no. of rows as argument.
• Syntax:DbContextclass referencevariable = new DbContextclass();
referencevariable.Dbsetname.Take(number of rows);
Take - Example
Creating Database
• Open SQL Server Management Studio. Select “Windows Authentication”. Click on “Connect”. Ignore
this step if “company” database already exists. Click on “New Query”. Type the following code:
• Click on “Execute” button. It shows “Query executed successfully” in the status bar.
Creating Project
• Open Visual Studio 2017. Go to “File” – “New” – “Project”. "New Project" dialogbox appears. Select “.NET
Framework 4.7”. Select “Visual C#”. Select “Console App (.NET Framework)”. Type the project name
“TakeExample”. Type the location as “C:\mvc”. Type the solution name as “TakeExample”. Click on OK.
Installing Packages
• Go to "Tools" menu – "NuGet Package Manager" – "Package Manager Console". "Package Manager Console"
window will be opened. Type the following command in "Package Manager Console" and press Enter.
install-package EntityFramework
First
• The First() method is used to select the first row of the table. The First() method doesn't receive any
argument. It returns exception, if no rows are found in the table.
• Syntax:DbContextclass referencevariable = new DbContextclass();
referencevariable.Dbsetname.First();
First - Example
Creating Database
• Open SQL Server Management Studio. Select “Windows Authentication”. Click on “Connect”. Ignore
this step if “company” database already exists. Click on “New Query”. Type the following code:
• Click on “Execute” button. It shows “Query executed successfully” in the status bar.
Creating Project
• Open Visual Studio 2017. Go to “File” – “New” – “Project”. "New Project" dialogbox appears. Select “.NET
Framework 4.7”. Select “Visual C#”. Select “Console App (.NET Framework)”. Type the project name
“FirstExample”. Type the location as “C:\mvc”. Type the solution name as “FirstExample”. Click on OK.
Installing Packages
• Go to "Tools" menu – "NuGet Package Manager" – "Package Manager Console". "Package Manager Console"
window will be opened. Type the following command in "Package Manager Console" and press Enter.
install-package EntityFramework
FirstOrDefault
• The FirstOrDefault() method is used to select the first row of the table.
• The FirstOrDefault() method doesn't receive any argument.
• It returns null, if no rows are found in the table.
• Syntax:DbContextclass referencevariable = new DbContextclass();
referencevariable.Dbsetname.FirstOrDefault();
FirstOrDefault - Example
Creating Database
• Open SQL Server Management Studio. Select “Windows Authentication”. Click on “Connect”. Ignore
this step if “company” database already exists. Click on “New Query”. Type the following code:
• Click on “Execute” button. It shows “Query executed successfully” in the status bar.
Creating Project
• Open Visual Studio 2017. Go to “File” – “New” – “Project”. "New Project" dialogbox appears. Select “.NET
Framework 4.7”. Select “Visual C#”. Select “Console App (.NET Framework)”. Type the project name
“FirstOrDefaultExample”. Type the location as “C:\mvc”. Type the solution name as “FirstOrDefaultExample”.
Click on OK.
Installing Packages
• Go to "Tools" menu – "NuGet Package Manager" – "Package Manager Console". "Package Manager Console"
window will be opened. Type the following command in "Package Manager Console" and press Enter.
install-package EntityFramework
Last
• The Last() method is used to select the last row of the table. The Last() method doesn't receive any
argument. It returns exception, if no rows are found in the table.
• Syntax:DbContextclass referencevariable = new DbContextclass();
referencevariable.Dbsetname.Last();
Last - Example
Creating Database
• Open SQL Server Management Studio. Select “Windows Authentication”. Click on “Connect”. Ignore
this step if “company” database already exists. Click on “New Query”. Type the following code:
• Click on “Execute” button. It shows “Query executed successfully” in the status bar.
Creating Project
• Open Visual Studio 2017. Go to “File” – “New” – “Project”. "New Project" dialogbox appears. Select “.NET
Framework 4.7”. Select “Visual C#”. Select “Console App (.NET Framework)”. Type the project name
“LastExample”. Type the location as “C:\mvc”. Type the solution name as “LastExample”. Click on OK.
Installing Packages
• Go to "Tools" menu – "NuGet Package Manager" – "Package Manager Console". "Package Manager Console"
window will be opened. Type the following command in "Package Manager Console" and press Enter.
install-package EntityFramework
LastOrDefault
• The LastOrDefault() method is used to select the last row of the table. The LastOrDefault() method
doesn't receive any argument. It returns null, if no rows are found in the table.
• Syntax:DbContextclass referencevariable = new DbContextclass();
referencevariable.Dbsetname.LastOrDefault();
LastOrDefault - Example
Creating Database
• Open SQL Server Management Studio. Select “Windows Authentication”. Click on “Connect”. Ignore
this step if “company” database already exists. Click on “New Query”. Type the following code:
• Click on “Execute” button. It shows “Query executed successfully” in the status bar.
Creating Project
• Open Visual Studio 2017. Go to “File” – “New” – “Project”. "New Project" dialogbox appears. Select “.NET
Framework 4.7”. Select “Visual C#”. Select “Console App (.NET Framework)”. Type the project name
“LastOrDefaultExample”. Type the location as “C:\mvc”. Type the solution name as “LastOrDefaultExample”.
Click on OK.
Installing Packages
• Go to "Tools" menu – "NuGet Package Manager" – "Package Manager Console". "Package Manager Console"
window will be opened. Type the following command in "Package Manager Console" and press Enter.
install-package EntityFramework
Join
• The Join() method is used to combine two tables based on primary key and reference key. The first model
class represents primary key table. The second model class represents reference key table. The third
model class represents joined table. The Join() method receives four arguments:
o argument 1: Second db set.
o argument 2: Primary key column.
o argument 3: Reference key column
o argument 4: Lambda expression that represents list of columns to retrieve.
• Syntax:DbContextclass referencevariable = new DbContextclass();
List<thirdmodelclass> joineddata = referencevariable.FirstDbsetname
.Join( referencevariable.SecondDbSetname, temp => temp.Primarykey,
temp2 => temp2.Referencekey,
(temp1, temp2) => new thirdmodelclass() { Column1 = temp1.Column1, Column2 = temp2.Column2,
… } ).ToList();
Join - Example
Creating Database
• Open SQL Server Management Studio. Select “Windows Authentication”. Click on “Connect”. Ignore this step
if “departmentsandemployees” database already exists. Click on “New Query”. Type the following code:
• Click on “Execute” button. It shows “Query executed successfully” in the status bar.
Creating Project
• Open Visual Studio 2017. Go to “File” – “New” – “Project”. "New Project" dialogbox appears. Select “.NET
Framework 4.7”. Select “Visual C#”. Select “Console App (.NET Framework)”. Type the project name
“JoinExample”. Type the location as “C:\mvc”. Type the solution name as “JoinExample”. Click on OK.
Installing Packages
• Go to "Tools" menu – "NuGet Package Manager" – "Package Manager Console". "Package Manager Console"
window will be opened. Type the following command in "Package Manager Console" and press Enter.
install-package EntityFramework
Aggregate Methods
• The aggregate methods combines all values of a column and returns a single value. The Sum() method
returns sum of all values of the column. The Average() method returns average of all values of the
column. The Min() method returns minimum value of all values of the column. The Max() method returns
maximum value of all values of the column. The Count() method returns count of all values of the column.
• Syntax:DbContextclass referencevariable = new DbContextclass();
decimal variable = referencevariable.Dbsetname.Select(temp => temp.columnname).Sum();
decimal variable = referencevariable.Dbsetname.Select(temp => temp.columnname).Average();
decimal variable = referencevariable.Dbsetname.Select(temp => temp.columnname).Min(); decimal
variable = referencevariable.Dbsetname.Select(temp => temp.columnname).Max(); decimal
variable = referencevariable.Dbsetname.Select(temp => temp.columnname).Count();
Creating Project
• Open Visual Studio 2017. Go to “File” – “New” – “Project”. "New Project" dialogbox appears. Select “.NET
Framework 4.7”. Select “Visual C#”. Select “Console App (.NET Framework)”. Type the project name
“AggregateOperatorsExample”. Type the location as “C:\mvc”. Type the solution
name as “AggregateOperatorsExample”. Click on OK.
Installing Packages
• Go to "Tools" menu – "NuGet Package Manager" – "Package Manager Console". "Package Manager Console"
window will be opened. Type the following command in "Package Manager Console" and press Enter.
install-package EntityFramework
"F5". Output:
Deferred Execution
• The LINQ query of EF executes when you call ToList(), First(), FirstOrDefault(), Last(), LastOrDefault() methods only;
If you don’t call any of these methods, the query will not execute. If you write the LINQ query in once
place, call any of the above specified methods in other place, we call it as deferred execution. That means
it executes differently, unlike regular statement, the LINQ query will be really processed / executed only
you call any of the above methods.
• Syntax:DbContextclass referencevariable = new DbContextclass();
IQueryable<modelclassname> query =
referencevariable.Dbsetname.Where(temp => temp.columnname);
List<modelclassname> listname = query.ToList();
Creating Project
• Open Visual Studio 2017. Go to “File” – “New” – “Project”. "New Project" dialogbox appears. Select “.NET
Framework 4.7”. Select “Visual C#”. Select “Console App (.NET Framework)”. Type the project name
“DeferredExecutionExample”. Type the location as “C:\mvc”. Type the solution
name as “DeferredExecutionExample”. Click on OK.
Installing Packages
• Go to "Tools" menu – "NuGet Package Manager" – "Package Manager Console". "Package Manager Console"
window will be opened. Type the following command in "Package Manager Console" and press Enter.
install-package EntityFramework
Non-Query Operations in EF
Insertion
• We can insert new rows into the table using EF. The Add() method just adds the new model object to the
existing virtual table. The SaveChanges() method automatically generates INSERT sql statement and
executes the same at database.
• Syntax:DbContextclass referencevariable = new DbContextclass();
Modelclass referencevariable2 = new Modelclass();
referencevariable2.property1 = value;
referencevariable2.property2 = value;
…
referencevariable.Dbsetname.Add(referencevariable2);
referencevariable.SaveChanges();
Insertion - Example
Creating Database
• Open SQL Server Management Studio. Select “Windows Authentication”. Click on “Connect”. Ignore
this step if “company” database already exists. Click on “New Query”. Type the following code:
• Click on “Execute” button. It shows “Query executed successfully” in the status bar.
Creating Project
• Open Visual Studio 2017. Go to “File” – “New” – “Project”. "New Project" dialogbox appears. Select “.NET
Framework 4.7”. Select “Visual C#”. Select “Console App (.NET Framework)”. Type the project name
“InsertionExample”. Type the location as “C:\mvc”. Type the solution name as “InsertionExample”. Click on OK.
Installing Packages
• Go to "Tools" menu – "NuGet Package Manager" – "Package Manager Console". "Package Manager Console"
window will be opened. Type the following command in "Package Manager Console" and press Enter.
install-package EntityFramework
Updation
• We can update (modify) existing rows of the table using EF. The FirstOrDefault() method gets an existing
row of the table. The SaveChanges() method automatically generates UPDATE sql statement and
executes the same at database.
• Syntax:DbContextclass referencevariable = new DbContextclass();
Modelclass referencevariable2 =
referencevariable.Dbsetname.Where(temp => condition).FirstOrDefault();
referencevariable2.property1 = value;
referencevariable2.property2 = value;
…
referencevariable.SaveChanges();
Updation - Example
Creating Database
• Open SQL Server Management Studio. Select “Windows Authentication”. Click on “Connect”. Ignore
this step if “company” database already exists. Click on “New Query”. Type the following code:
• Click on “Execute” button. It shows “Query executed successfully” in the status bar.
Creating Project
• Open Visual Studio 2017. Go to “File” – “New” – “Project”. "New Project" dialogbox appears. Select “.NET
Framework 4.7”. Select “Visual C#”. Select “Console App (.NET Framework)”. Type the project name
“UpdationExample”. Type the location as “C:\mvc”. Type the solution name as “UpdationExample”. Click on OK.
Installing Packages
• Go to "Tools" menu – "NuGet Package Manager" – "Package Manager Console". "Package Manager
Console" window will be opened.
• Type the following command in "Package Manager Console" and press Enter.
install-package EntityFramework
Deletion - Example
Creating Database
• Open SQL Server Management Studio. Select “Windows Authentication”. Click on “Connect”. Ignore
this step if “company” database already exists. Click on “New Query”. Type the following code:
• Click on “Execute” button. It shows “Query executed successfully” in the status bar.
Creating Project
• Open Visual Studio 2017. Go to “File” – “New” – “Project”. "New Project" dialogbox appears. Select “.NET
Framework 4.7”. Select “Visual C#”. Select “Console App (.NET Framework)”. Type the project name
“DeletonExample”. Type the location as “C:\mvc”. Type the solution name as “DeletionExample”. Click on OK.
Installing Packages
• Go to "Tools" menu – "NuGet Package Manager" – "Package Manager Console". "Package Manager Console"
window will be opened. Type the following command in "Package Manager Console" and press Enter.
install-package EntityFramework
• Click on “Execute” button. It shows “Query executed successfully” in the status bar.
Creating Project
• Open Visual Studio 2017. Go to “File” – “New” – “Project”. "New Project" dialogbox appears. Select
“.NET Framework 4.7”. Select “Visual C#”. Select “Console App (.NET Framework)”. Type the project
name “StoredProcExample”. Type the location as “C:\mvc”. Type the solution name as
“StoredProcExample”. Click on OK.
Installing Packages
• Go to "Tools" menu – "NuGet Package Manager" – "Package Manager Console". "Package Manager Console"
window will be opened. Type the following command in "Package Manager Console" and press Enter.
install-package EntityFramework
Creating Project
• Open Visual Studio 2017. Go to “File” – “New” – “Project”. "New Project" dialogbox appears. Select “.NET
Framework 4.7”. Select “Visual C#”. Select “Console App (.NET Framework)”. Type the project name
“StoredProcWithParams”. Type the location as “C:\mvc”. Type the solution name as “StoredProcWithParams”.
Click on OK.
Installing Packages
• Go to "Tools" menu – "NuGet Package Manager" – "Package Manager Console". "Package Manager Console"
window will be opened. Type the following command in "Package Manager Console" and press Enter.
install-package EntityFramework
Data Annotations
• Data Annotations are the attributes present in "System.ComponentModel.DatAnnotations" namespace or
"System.ComponentModel.DataAnnotations.Schema" namespace. These are used to specify settings of
the model class or properties.
[Table] Used to specify table name, to which the model class is binded.
[Column] Used to specify the column name, to which the property is binded.
[NotMapped] Specifies that the property should not be stored in the database table.
[DatabaseGenerated] Specifies whether the primary key column is auto-generated (identity) or normal
column.
• Click on “Execute” button. It shows “Query executed successfully” in the status bar.
Creating Project
• Open Visual Studio 2017. Go to “File” – “New” – “Project”. "New Project" dialogbox appears. Select
“.NET Framework 4.7”. Select “Visual C#”. Select “Console App (.NET Framework)”. Type the
project name “DataAnnotationsExample”. Type the location as “C:\mvc”. Type the solution name
as “DataAnnotationsExample”. Click on OK.
Installing Packages
• Go to "Tools" menu – "NuGet Package Manager" – "Package Manager Console". "Package Manager Console"
window will be opened. Type the following command in "Package Manager Console" and press Enter.
install-package EntityFramework
Fundamentals of MVC
Introduction to ASP.NET MVC
• “ASP.NET MVC” is a “web application framework”, which is used to develop server side programs for web applications
using “MVC architecture”. MVC full form is “Model – View – Controller”. ASP.NET MVC supports “MVC architecture”.
ASP.NET MVC’s first version was released in 2009. "ASP.NET MVC" is a part of "ASP.NET". "ASP.NET
MVC" is an alternative to "ASP.NET Web Forms".
• Language: It is a set of rules and syntaxes to write programs to communicate with system. Ex: C, Java, C#.NET etc.
• Design Pattern: It is a known solution for known problem in design. Ex: Factory, Abstract, Singleton etc.
• Architecture: It is a pictural representation of components (Layers), which defines structure of the
application. Ex: Three-Tier Architecture, MVC architecture, MVVM architecture etc.
• Framework: It is a ready-made project skeleton, which is developed based on a specific language, specific
design pttern and specific architecture, to create specific type of applications. The framework provides built-
in code for common project tasks and let the developers to develop realtime applications easily and faster.
Ex: ASP.NET MVC, Spring, Cake PHP etc.
1. Controller calls Model (Controller creates object for the model class).
2. Controller calls View.
3. View calls Model (View gets data from model object).
Click on “Install”.
Wait for installation to be completed.
Click on “Restart”.
After restarting your system, go to “Start” > “Visual Studio 2017”.
If you have Microsoft account already and click on “Sign in” and complete the login process.
If you don’t have Microsoft account, click on “Sign up” and complete the registration process.
Note: If you don’t want to login, click on “Not now, may be later”; but then Visual Studio expires in 30 days.
If you click on “Sign up”, you will get the following page.
You will get a security code to your email. Login into your gmail, check the code that you have received
and enter it in this page.
After entering the security code, click on “Next”.
• Select “Empty”.
• Uncheck all the checkboxes (in case of any selected).
• Click on OK.
• Open Solution Explorer.
• Go to "Tools" menu – "NuGet Package Manager" – "Package Manager Console".
• "Package Manager Console" window will be opened.
• Right click on the project (App1) and click on "Add" – "New Item".
• Click on "Web" – "Global Application Class". Filename is "Global.asax" (automatically displayed). Click on "Add".
• It generates several methods like "Application_Start()", "Session_Start()", "Application_Error()" etc.
• Replace the code for "Global.asax" file as follows:
• Right click on the project (App1) and click on "Add" – "New Item".