1.新建项目,下载Nuget安装包
创建项目需要注意几点,如果是基于 .net framework 的项目 需要选择 相应版本的 EF, 如果是跨平台则选择EF Core版本。
我这里选择的是 .net framework 版本。红框里面是 实现EF Code First 需要的包。
对应的版本:
EntityFramework 6.3.0
MySql.Data 6.8.8
MySql.Data.Entities 6.8.3
如果是连接SqlServer 很简单,直接下载 EntityFramework 6.3.0 这个一个包就行了。程序集会引入这两个组件。然后编写代码即可。
针对MySQL 需要再下载这两个包
下载完成后设置App.config或者 Web.config 文件 ,这一步下载包的时候一般会自动添加,如果没有的话就手动加一下
<entityFramework><providers><provider invariantName="System.Data.SqlClient" type="System.Data.Entity.SqlServer.SqlProviderServices, EntityFramework.SqlServer" /><provider invariantName="MySql.Data.MySqlClient" type="MySql.Data.MySqlClient.MySqlProviderServices, MySql.Data.Entity.EF6, Version=6.8.3.0, Culture=neutral, PublicKeyToken=c5687fc88969c44d"></provider></providers></entityFramework>
2.创建EFModel
using System; using System.Collections.Generic; using System.ComponentModel.DataAnnotations; using System.ComponentModel.DataAnnotations.Schema; using System.Data.Entity; using System.Linq; using System.Text; using System.Threading.Tasks;namespace ConsoleWebSocket.Models {[Table("BaseDevice")]public class BaseDevice{[Key]public int Id { get; set; }public string Name { get; set; }public string Description { get; set; }}public class BaseDeviceDbContext : DbContext{public BaseDeviceDbContext(): base("myConn"){Database.SetInitializer(new DropCreateDatabaseIfModelChanges<BaseDeviceDbContext>());}public DbSet<BaseDevice> BaseDevice { get; set; }} }
4.操作数据库 测试
/// <summary>/// code first /// </summary>public static void TestCodeFirst(){using (var context = new BaseDeviceDbContext()){// 查询数据List<BaseDevice> models = context.BaseDevice.ToList();// 添加数据context.BaseDevice.Add(new BaseDevice { Id = 1, Name = "New Model", Description= "Description" });context.BaseDevice.Add(new BaseDevice { Id = 3, Name = "New Model", Description = "Description" });context.SaveChanges();//// 更新数据var model = context.BaseDevice.FirstOrDefault(m => m.Id == 1);if (model != null){model.Name = "Updated Name";context.SaveChanges();}// 删除数据 context.BaseDevice.Remove(model);context.SaveChanges();}}