ETJava Beta | Java    注册   登录
  • 搜索:
  • 使用EF 连接 数据库 SQLserver、MySql 实现 CodeFirst

    发表于      阅读(1)     博客类别:Crawler     转自:https://www.cnblogs.com/motion/p/18281201
    如有侵权 请联系我们删除  (页面底部联系我们)  

    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();
                }
            }