NuGet Packages
- Microsoft.EntityFrameworkCore.SqlServer
- Microsoft SQL Server database provider for Entity Framework Core.
- Microsoft.EntityFrameworkCore.Tools
- Entity Framework Core Tools for the NuGet Package Manager Console in Visual Studio.
Design
data:image/s3,"s3://crabby-images/45040/45040040a48c9b96382340a77dc2b7200e235969" alt=""
Code
- Models\Customer.cs
using System;
using System.Collections.Generic;
using System.Text;
namespace ContosoPets.Models
{
public class Customer
{
public int Id { get; set; }
public string FirstName { get; set; }
public string LastName { get; set; }
public string? Address { get; set; }
public string? Phone { get; set; }
public string Email { get; set; }
public ICollection<Order> Orders { get; set; }
}
}
- Models\Product.cs
using System;
using System.Collections.Generic;
using System.ComponentModel.DataAnnotations;
using System.ComponentModel.DataAnnotations.Schema;
using System.Text;
namespace ContosoPets.Models
{
public class Product
{
public int Id { get; set; }
[Required]
public string Name { get; set; }
[Column(TypeName = "decimal(18, 2)")]
public decimal Price { get; set; }
}
}
- Models\Order.cs
using System;
using System.Collections.Generic;
namespace ContosoPets.Models
{
public class Order
{
public int Id { get; set; }
public DateTime OrderPlaced { get; set; }
public DateTime? OrderFulfilled { get; set; }
public int CustomerId { get; set; }
public Customer Customer { get; set; }
public ICollection<ProductOrder> ProductOrders { get; set; }
}
}
- Models\ProductOrder.cs
namespace ContosoPets.Models
{
public class ProductOrder
{
public int Id { get; set; }
public int Quantity { get; set; }
public int ProductId { get; set; }
public int OrderId { get; set; }
public Order Order { get; set; }
public Product Product { get; set; }
}
}
- Data\ContosPetsContext.cs
using ContosoPets.Models;
using Microsoft.EntityFrameworkCore;
using System;
using System.Collections.Generic;
using System.Text;
namespace ContosoPets.Data
{
class ContosoPetsContext : DbContext
{
public DbSet<Customer> Customers { get; set; }
public DbSet<Order> Orders { get; set; }
public DbSet<Product> Products { get; set; }
public DbSet<ProductOrder> ProductOrders { get; set; }
protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)
{
optionsBuilder.UseSqlServer("Data Source=(localdb)\\MSSQLLocalDB;" +
"Initial Catalog=ContosoPets;" +
"Integrated Security=True;" +
"Connect Timeout=30;" +
"Encrypt=False;" +
"TrustServerCertificate=False;" +
"ApplicationIntent=ReadWrite;" +
"MultiSubnetFailover=False");
}
}
}
- Program.cs
using ContosoPets.Data;
using ContosoPets.Models;
using System;
using System.Linq;
namespace ContosoPets
{
class Program
{
static void Main(string[] args)
{
using ContosoPetsContext context = new ContosoPetsContext();
// 1. Add Products //////////////////////////////
Product squeakyBone = new Product()
{
Name = "Squeaky Dog Bone",
Price = 4.99M
};
context.Products.Add(squeakyBone);
Product tennisBalls = new Product()
{
Name = "Tennis Ball 3-Pack",
Price = 9.99M
};
context.Add(tennisBalls);
context.SaveChanges();
/////////////////////////////////////////////////
// 3-1. Modify Database /////////////////////////
var squeakyBone = context.Products
.Where(p => p.Name == "Squeaky Dog Bone")
.FirstOrDefault();
if(squeakyBone is Product)
{
squeakyBone.Price = 7.99m;
// 3-2. Remove Entity /////////////////////////
context.Remove(squeakyBone);
///////////////////////////////////////////////
}
context.SaveChanges();
// 2-1. Query with Fluent API Syntex ////////////
var products = context.Products
.Where(p => p.Price >= 5.00m)
.OrderBy(p => p.Name);
/////////////////////////////////////////////////
// 2-2. Query with Link Syntax //////////////////
var products = from product in context.Products
where product.Price > 5.00m
orderby product.Name
select product;
/////////////////////////////////////////////////
// 1. Print ///////////////////////////////////
foreach(Product p in products)
{
Console.WriteLine($"Id: {p.Id}");
Console.WriteLine($"Name: {p.Name}");
Console.WriteLine($"Price: {p.Price}");
Console.WriteLine(new string('-',20));
}
/////////////////////////////////////////////////
}
}
}
Package Manager Console
- Add-Migration [Name]
- Creates a new migration class as per specified name with the
Up()
andDown()
methods.
- Creates a new migration class as per specified name with the
Add-Migration AddEmail
data:image/s3,"s3://crabby-images/e1b23/e1b23b2b9f3f63e4350b2dbcbbf8189ad9bda6d2" alt=""
data:image/s3,"s3://crabby-images/5efc8/5efc86cbf312f12c5074909b0fb07a87b0fa9249" alt=""
data:image/s3,"s3://crabby-images/26fd9/26fd9511065a0ff992b58aed11802214fd4abaae" alt=""
- Update-Database
- Executes the last migration file created by the
Add-Migration
command and applies changes to the database schema.
- Executes the last migration file created by the
Update-Database
data:image/s3,"s3://crabby-images/85ba2/85ba2b1ea0ca959ecfcb02eda7062d491f2d38bf" alt=""
data:image/s3,"s3://crabby-images/c326b/c326b0178dd19688a4e336c4ca4172e58e5c068d" alt=""
data:image/s3,"s3://crabby-images/078b1/078b14f6d588aa0027501770c2d52be065bc486e" alt=""
String?
- nullable
public string? Address { get; set; }
public string? Phone { get; set; }
ICollection
- Defines methods to manipulate generic collections.
- ICollection is a interface that represents a collection, it also contains strongly typed members
public ICollection<Order> Orders { get; set; }
DataAnnotations
- DataAnnotations are used in MVC to validate the data.
- It works on Client-side as well as server side.
- There are some pre-defined data-annotation attributes which we use directly to validate the data
- [Required]
- the property should be not null or the property should not be a string type, which is either empty or whitespace
[Required]
public string Name { get; set; }
- [Column(TypeName = “[Datatype Condition]”]
- Condition of Column
[Column(TypeName = "decimal(18, 2)")]
public decimal Price { get; set; }
DbContext
- DbContext
- DbContext is called context class in entity framework.
- DbContext is the primary class that is responsible for interacting with the database
Querying: Converts LINQ-to-Entities queries to SQL query and sends them to the database.
Change Tracking: Keeps track of changes that occurred on the entities after querying from the database.
Persisting Data: Performs the Insert, Update and Delete operations to the database, based on entity states.
Caching: Provides first level caching by default. It stores the entities which have been retrieved during the life time of a context class.
Manage Relationship: Manages relationships using CSDL, MSL and SSDL in Db-First or Model-First approach, and using fluent API configurations in Code-First approach.
Object Materialization: Converts raw data from the database into entity objects.
class ContosoPetsContext : DbContext
- DbSet
- The
DbSet
class represents an entity set that can be used for create, read, update, and delete operations. - The
DbContext
must include the DbSet type properties for the entities which map to database tables and views.
- The
public DbSet<Customer> Customers { get; set; }
public DbSet<Order> Orders { get; set; }
public DbSet<Product> Products { get; set; }
public DbSet<ProductOrder> ProductOrders { get; set; }
Override
- The override modifier is required to extend or modify the abstract or virtual implementation of an inherited method, property, indexer, or event.
- An override method provides a new implementation of the method inherited from a base class.
- The method that is overridden by an override declaration is known as the overridden base method.
- An override method must have the same signature as the overridden base method.
protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)
DbContextOptionsBuilder
- Provides a simple API surface for configuring DbContextOptions.
- Databases (and other extensions) typically define extension methods on this object that allow you to configure the database connection (and other options) to be used for a context.
- You can use DbContextOptionsBuilder to configure a context by overriding OnConfiguring(DbContextOptionsBuilder) or creating a DbContextOptions externally and passing it to the context constructor.
protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)
UseSqlServer
- UseSqlServer
- Configures the context to connect to a Microsoft SQL Server database, but without initially setting any DbConnection or connection string.
- The connection or connection string must be set before the DbContext is used to connect to a database.
optionsBuilder.UseSqlServer("Data Source=(localdb)\\MSSQLLocalDB;" +
"Initial Catalog=ContosoPets;" +
"Integrated Security=True;" +
"Connect Timeout=30;" +
"Encrypt=False;" +
"TrustServerCertificate=False;" +
"ApplicationIntent=ReadWrite;" +
"MultiSubnetFailover=False");
Connection String Syntax
- Data Source
- To connect to a named instance of SQL Server, use the
server name\instance
name syntax. - You can also set the DataSource property of the
SqlConnectionStringBuilder
to the instance name when building a connection string. - The
DataSource
property of aSqlConnection
object is read-only.
- To connect to a named instance of SQL Server, use the
"Data Source=(localdb)\\MSSQLLocalDB;"
- Initial Catalog
- If the user name that is in the connection string has access to more then one database, you have to specify the database you want the connection string to connect to.
"Initial Catalog=ContosoPets;"
- Intergrated Security
- When
false
, User ID and Password are specified in the connection. - When
true
, the current Windows account credentials are used for authentication.
- When
"Integrated Security=True;"
- Connect Timeout
- The length of time (in seconds) to wait for a connection to the server before terminating the attempt and generating an error.
"Connect Timeout=30;"
- Encrypt
- When true, SQL Server uses SSL encryption for all data sent between the client and server if the server has a certificate installed.
"Encrypt=False;"
- TrustServerCertificate
- The
TrustServerCertificate
keyword is valid only when connecting to aSQL Server instance
with a valid certificate. - When
TrustServerCertificate
is set totrue
, the transport layer will useSSL
to encrypt the channel and bypass walking the certificate chain to validate trust.
- The
"TrustServerCertificate=False;"
- ApplicationIntent
- The keyword ApplicationIntent can be specified in your connection string. The assignable values are ReadWrite or ReadOnly. The default is ReadWrite.
- When ApplicationIntent=ReadOnly, the client requests a read workload when connecting. The server enforces the intent at connection time, and during a USE database statement.
- The ApplicationIntent keyword does not work with legacy read-only databases.
"ApplicationIntent=ReadWrite;"
- MultiSubnetFailover
- Always specify
MultiSubnetFailover=Yes
when connecting to a SQL Server 2012 availability group listener or SQL Server 2012 Failover Cluster Instance. MultiSubnetFailover enables faster failover for all Availability Groups and failover cluster instance in SQL Server 2012 and will significantly reduce failover time for single and multi-subnet Always On topologies. During a multi-subnet failover, the client will attempt connections in parallel. During a subnet failover, SQL Server Native Client will aggressively retry the TCP connection. - The MultiSubnetFailover connection property indicates that the application is being deployed in an availability group or Failover Cluster Instance, and that SQL Server Native Client will try to connect to the database on the primary SQL Server instance by trying to connect to all the IP addresses. When
MultiSubnetFailover=Yes
is specified for a connection, the client retries TCP connection attempts faster than the operating system’s default TCP retransmit intervals. This enables faster reconnection after failover of either an Always On Availability Group or an Always On Failover Cluster Instance, and is applicable to both single- and multi-subnet Availability Groups and Failover Cluster Instances.
- Always specify
"MultiSubnetFailover=False"
Result
data:image/s3,"s3://crabby-images/01afb/01afb9a4eb1d8e973f85e49285fdff8137afae72" alt=""
data:image/s3,"s3://crabby-images/6d9b0/6d9b05b0128ccf557fa95459089dbacb686bdec1" alt=""
data:image/s3,"s3://crabby-images/b60bf/b60bf653d2007e50c8d0ae13623b3246fdb9d3fd" alt=""
data:image/s3,"s3://crabby-images/60584/6058428a7bba2603db7ac80aa5861cdb2dc701e7" alt=""
data:image/s3,"s3://crabby-images/c73a0/c73a04afef7a1ecd420c7e5fb817c85889df9f1a" alt=""