时间:2017-03-09
系列文章:
EF-ModelFirst实现过程
EF-CodeFirst实现过程(详细)+数据库迁移
建议学习路径 DBFirst->ModelFirst->CodeFirst
思路:通过SQL Server 2014 Management Studio设计好数据库之后,根据数据库生成实体和上下文。
1,设计数据库
新建数据库以及数据表
设置主键,并将主键设置为标识列(主键自增)。
data:image/s3,"s3://crabby-images/dc8c8/dc8c841c0468f270d11a2ad8b5e2f532742d99bc" alt=""
data:image/s3,"s3://crabby-images/6a5bc/6a5bc728affcfc680c30d8d17159d4f9f7b9f834" alt=""
2,新建项目
文件->新建->项目->控制台应用程序
data:image/s3,"s3://crabby-images/d5dc2/d5dc2b27e18f7c14d370cd996e083db2a7db2994" alt=""
项目->添加->数据->ADO.NET实体数据模型。
data:image/s3,"s3://crabby-images/49630/49630fbc9846246d3bbee0eea7275f2ff4f51fe4" alt=""
来自数据库的EF设计器
data:image/s3,"s3://crabby-images/5a92b/5a92b0413b8dcf2c9eb55fff8cc2690aff4bbced" alt=""
新建连接
服务器名的获取:
data:image/s3,"s3://crabby-images/a2002/a20026592b7779d8486f6ca4c9bb949328eb3a23" alt=""
data:image/s3,"s3://crabby-images/49295/49295f19d4f9fa78935df72715b9b3ed35310d2f" alt=""
data:image/s3,"s3://crabby-images/d966c/d966c4c4176f76cc2abcfbe5cfd9d3f3baadcd70" alt=""
此时项目文件为:
data:image/s3,"s3://crabby-images/6ddd0/6ddd07e1252adc7d669947b708b55f19638e4aa0" alt=""
在Model1.Context.cs下找到上下文,并Ctrl+C
data:image/s3,"s3://crabby-images/7e315/7e315cb9ea31d0e8d8914d1317dfb5c90047e6a6" alt=""
到Program.cs下编写代码实现EF增删改查
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
namespace EF_DBFirst_Demo
{
class Program
{
static void Main(string[] args)
{
//使用using的原因:因为连接数据库是非常占用资源的,所以我们要及时释放,using的作用就是在代码块执行完毕后立即释放资源,不需等待CLR的资源回收机制处理。
//1.实例化上下文对象
using (EF_DBFirstDemoEntities dbContext=new EF_DBFirstDemoEntities())
{
//2.实例化对象实例
Customer customer_A = new Customer();
customer_A.CreateTime=DateTime.Now;
customer_A.CreateBy = "Fnatic";
customer_A.CustomerName = "FutaoSmile";
//不需要指定id,因为id是自增的,所以数据库会自动赋值,我们在这边赋值了也是没用的。
//3.告诉EF我们要对哪张表进行什么样的操作
dbContext.Customer.Add(customer_A);
//4.将数据同步到数据库
dbContext.SaveChanges();
}
//修改数据的第二种方法。(第一种方法请参见下面给出的链接)
1.实例化上下文对象
using (EF_DBFirstDemoEntities dbContext=new EF_DBFirstDemoEntities())
{
//2.根据ID从数据库获取对应的数据并赋值给一个实例化的对象
Customer customer= dbContext.Customer.FirstOrDefault(u => u.CustomerID==2);
//或 Customer customer = dbContext.Customer.Find(2);
//3.更改需要更改的值
customer.CreateBy = "Admin";
customer.CreateTime = DateTime.Now;
//4.将数据同步到数据库
dbContext.SaveChanges();
}
}
}
增删改查的实现请参见我的另一篇文章:http://www.jianshu.com/nb/10166743
谢谢O(∩_∩)O~</br>
网友评论