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

usingSystem;usingSystem.Collections.Generic;usingSystem.ComponentModel.DataAnnotations;usingSystem.ComponentModel.DataAnnotations.Schema;usingSystem.Data.Entity;usingSystem.Linq;usingSystem.Text;usingSystem.Threading.Tasks;namespaceConsoleWebSocket.Models
{
[Table(
"BaseDevice")]public classBaseDevice
{
[Key]
public int Id { get; set; }public string Name { get; set; }public string Description { get; set; }
}
public classBaseDeviceDbContext : DbContext
{
publicBaseDeviceDbContext()
:
base("myConn")
{
Database.SetInitializer(
new DropCreateDatabaseIfModelChanges<BaseDeviceDbContext>());
}
public DbSet<BaseDevice> BaseDevice { get; set; }
}
}

4.操作数据库 测试

        /// <summary>
        ///code first/// </summary>
        public static voidTestCodeFirst()
{
using (var context = newBaseDeviceDbContext())
{
//查询数据 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();
}
}

标签: none

添加新评论