Lerning Entity Framework 6 ------ Inserting, Querying, Updating, and Deleting Data
Creating Entities
First of all, Let's create some entities to have a test.
- Create a project
- Add following packages by NuGet
- EntityFramework
- MySql.Data.Entity (I'm just using MySql, it's not necessary)
Add some codes:
class Class
{
public int ClassId { get; set; } [MaxLength(50)]
public string ClassName { get; set; } public virtual ICollection<Student> Students { get; set; }
} class Student
{
public int StudentId { get; set; } [MaxLength(50)]
public string StudentName { get; set; } public int Age { get; set; } public virtual Class Class { get; set; } public virtual ICollection<Course> Courses { get; set; } public virtual ICollection<Phone> Phones { get; set; }
} class Phone
{
public int phoneId { get; set; } [MaxLength(20)]
public string PhoneNumber { get; set; }
} class Course
{
public int CourseId { get; set; } [MaxLength(50)]
public string CourseName { get; set; } public virtual ICollection<Student> Students { get; set; }
} class MyContext:DbContext
{
public MyContext():base("name=Test")
{ } public DbSet<Class> Classes { get; set; } public DbSet<Student> Students { get; set; } public DbSet<Course> Courses { get; set; }
}
Then, Execute following commands in NuGet command line
- Enalbe-Migrations
- Add-Migration init
- Update-Database
Inserting
Add some codes in main function:
static void Main(string[] args)
{
Class class1 = new Class { ClassName = "Class One", };
Course course1 = new Course { CourseName = "English", };
Course course2 = new Course { CourseName = "Chinese", };
Student s1 = new Student
{
Age = 18,
Class = class1,
Courses = new List<Course> { course1, course2 },
Phones = new List<Phone> {
new Phone { PhoneNumber = "13718431702"},
new Phone { PhoneNumber = "13733423722" } },
StudentName = "Joye"
};
Student s2 = new Student
{
Age = 19,
Class = class1,
Courses = new List<Course> { course1 },
Phones = new List<Phone> {
new Phone { PhoneNumber = "13708431702"},
new Phone { PhoneNumber = "13783423722" } },
StudentName = "Ross"
};
Student s3 = new Student
{
Age = 17,
Class = class1,
Courses = new List<Course> { course2 },
Phones = new List<Phone> { new Phone { PhoneNumber = "13708431702" } },
StudentName = "Monnica"
};
using (MyContext db = new MyContext())
{
db.Students.Add(s1);
db.Students.Add(s2);
db.Students.Add(s3);
db.SaveChanges();
}
}
I've created one class, two courses, three students and five phone numbers. Then, I add the three studengs to the Studengs DbSet and called the SaveChanges function. That all I did. Maybe you will say: Why don't we need to add all of the entities to the Dbset. When Entity Framework saves a entity, it also saves the whole object graph. How cool it is.
Querying
Filtering data in queries
using (MyContext db = new MyContext())
{
var students = db.Students.Where(s => s.Age > 17);
foreach (var item in students)
{
Console.WriteLine(item.StudentName + " " + item.Age);
}
}
Console.Read();
You can do this by LINQ too.
Sorting data in queries
using (MyContext db = new MyContext())
{
var students = db.Students
.OrderBy(s => s.Age)
.ThenBy(s => s.StudentName);
foreach (var item in students)
{
Console.WriteLine(item.StudentName + " " + item.Age);
}
}
Console.Read();
Working with related entities
static void Main(string[] args)
{
using (MyContext db = new MyContext())
{
var students = from s in db.Students
where s.Courses.Any(c => c.CourseName == "Chinese")
select s;
foreach (var item in students)
{
Console.WriteLine(item.StudentName + " " + item.Age);
}
}
Console.Read();
}
Loading Related Entities
there are three ways of loading related entities:
Lazy Loading
This way is the default way of Entity Framework 6. Lazy loading is the process whereby an entity or collection of entities is automatically loaded from the database the first time that a property referring to the entity/entities is accessed.(MSND) There are two rules you must pay attention to:
- The model must be defined as public
- the navigation property must be defined as virtual
For example:
using (MyContext db = new MyContext())
{
Student oneStudent = db.Students.Find(1); //query the database for the first time
foreach (var item in oneStudent.Phones) //query the database for the second time
{
Console.WriteLine(item.PhoneNumber);
}
}
You can turn lazy loading off by two ways:
- Remove the public key of model or remove the virtual key of navigation property
- Set the Configuration.LazyLoadingEnabled property of DbContext flase
Eagerly Loading
Eager loading is the process whereby a query for one type of entity also loads related entities as part of the query. Eager loading is achieved by use of the Include method.(MSND) For example:
using (MyContext db = new MyContext())
{
db.Configuration.LazyLoadingEnabled = false;
var students = from s in db.Students.Include(s => s.Phones)
where s.StudentName == "Joye"
select s;
foreach (var s in students)
{
foreach (var p in s.Phones)
{
Console.WriteLine(p.PhoneNumber);
}
}
}
using (MyContext db = new MyContext())
{
db.Configuration.LazyLoadingEnabled = false;
var courses = from c in db.Courses.Include(cc => cc.Students.Select(s => s.Phones))
where c.CourseName == "English"
select c;
Console.WriteLine(courses.First().Students.First().Phones.First().PhoneNumber);
}
Explicitly Loading
Even with lazy loading disabled it is still possible to lazily load related entities, but it must be done with an explicit call. To do so you use the Load method on the related entity’s entry.(MSND) For example:
using (MyContext db = new MyContext())
{
db.Configuration.LazyLoadingEnabled = false;
Course c = db.Courses.Find(1);
db.Entry(c)
.Collection(cc => cc.Students)
.Load();
Console.WriteLine(c.Students.Count);
}
If the navigation property is a single entity, please use Reference method. If the navigation property is a collection of entities, please use method Collection.
Updating
using (MyContext db = new MyContext())
{
var sutdent = db.Students.Find(1);
sutdent.StudentName = "Joey";
db.SaveChanges();
}
Or:
using (MyContext db = new MyContext())
{
var sutdent = new Student
{
StudentId = 1,
StudentName = "Joeyy"
};
db.Entry(sutdent).State = EntityState.Modified;
db.SaveChanges();
}
Deleting
using (MyContext db = new MyContext())
{
var student = db.Students.Find(1);
var course = db.Courses.Find(1);
course.Students.Remove(student);
db.SaveChanges();
}
After you run the codes, one of the rows of table coursestudents is deleted. If you remove a entity from db.Students, one of the rows of table people will be deleted.
You can also use entry method:
using (MyContext db = new MyContext())
{
var phone = new Phone { phoneId = 1 };
db.Entry(phone).State = EntityState.Deleted;
db.SaveChanges();
}
That's all.
Lerning Entity Framework 6 ------ Inserting, Querying, Updating, and Deleting Data的更多相关文章
- Lerning Entity Framework 6 ------ Defining Relationships
There are three types of relationships in database. They are: One-to-Many One-to-One Many-to-Many Th ...
- MySQL Crash Course #11# Chapter 20. Updating and Deleting Data
INDEX Updating Data The IGNORE Keyword Deleting Data Faster Deletes Guidelines for Updating and Dele ...
- Lerning Entity Framework 6 ------ Handling concurrency With SQL Server Database
The default Way to handle concurrency of Entity Framework is using optimistic concurrency. When two ...
- Lerning Entity Framework 6 ------ Working with in-memory data
Sometimes, you need to find some data in an existing context instead of the database. By befault, En ...
- Lerning Entity Framework 6 ------ Defining the Database Structure
There are three ways to define the database structure by Entity Framework API. They are: Attributes ...
- Lerning Entity Framework 6 ------ Introduction to TPH
Sometimes, you have created two models. They have the same parent class like this: public class Pers ...
- Entity Framework优化一:引发了“System.Data.Entity.Core.EntityCommandExecutionException”类型的异常
错误信息: “System.Data.Entity.Core.EntityCommandExecutionException”类型的异常在 EntityFramework.SqlServer.dll ...
- Lerning Entity Framework 6 ------ Complex types
Complex types are classes that map to a subset of columns of a table.They don't contains key. They a ...
- Lerning Entity Framework 6 ------ Using a commandInterceptor
Sometimes, We want to check the original sql statements. creating a commandInterceptor is a good way ...
随机推荐
- 20155312 张竞予 2006-2007-2 《Java程序设计》第四周学习总结
20155312 2006-2007-2 <Java程序设计>第四周学习总结 课堂笔记 Ctrl+shift+T调出三个窗口,分别是"vi编写代码","jav ...
- ManageEngine的EventLog Analyzer许可信息
- lower_case_table_names
http://blog.csdn.net/jesseyoung/article/details/40617031 1 简介 在MySQL中,数据库对应数据目录中的目录.数据库中的每个表至少对应数 ...
- static与非static的区别
static 静态的,可以修饰变量或者方法 用于变量的区别 1. static 修饰的变量称为类变量或全局变量或成员变量,在类被加载的时候成员变量即被初始化,与类关联,只要类存在,static变量就存 ...
- 2018.11.02 NOIP训练 停车场(线段树)
传送门 这是一道困饶了我一年的题. 其实就是去年去NOIP提高组试水的时候考的模拟题 但当时我水平不够,跟ykykyk一起杠了一个下午都没调出来. 今天终于AAA了. 其实就是一个维护最长连续0101 ...
- vue+mui轮播图
mui的轮播图,如果图片是请求来的,直接在html中循环是不会动的. 需要请求完图片之后,在setTimeout方法里,使用slider()方法,这样才会动 而且mui的轮播图,有点坑的,需要重复最后 ...
- 点击文字弹出一个DIV层窗口代码
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html> <hea ...
- 第24章:MongoDB-聚合操作--MapReduce
①MapReduce 在MongoDB的聚合框架中,还可以使用MapReduce,它非常强大和灵活,但具有一定的复杂性,专门用于实现一些复杂的聚合功能. MongoDB中的MapReduce使用Jav ...
- vmware虚拟机centOs安装教程
1安装vmware 虚拟机软件 1.解压vmware安装 汉化vmware虚拟机 复制注册码,并填写进vmware 2安装linux(centos)虚拟机 1. 点击文件----->新建虚拟机 ...
- 安卓修改开机logo
这里我们是在ubuntu下进行操作我是用root用户登陆的,首先安装netpbm库 执行:apt-get install netpbm 对于Android系统最开始表现logo是在内核当中,所以首先我 ...