经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 数据库/运维 » MySQL » 查看文章
使用EF 连接 数据库 SQLserver、MySql 实现 CodeFirst
来源:cnblogs  作者:宁静致远·TangJ  时间:2024/7/3 14:35:46  对本文有异议

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 文件  ,这一步下载包的时候一般会自动添加,如果没有的话就手动加一下

  1. <entityFramework>
  2. <providers>
  3. <provider invariantName="System.Data.SqlClient" type="System.Data.Entity.SqlServer.SqlProviderServices, EntityFramework.SqlServer" />
  4. <provider invariantName="MySql.Data.MySqlClient" type="MySql.Data.MySqlClient.MySqlProviderServices, MySql.Data.Entity.EF6, Version=6.8.3.0, Culture=neutral, PublicKeyToken=c5687fc88969c44d"></provider>
  5. </providers>
  6. </entityFramework>

2.创建EFModel

  1. using System;
  2. using System.Collections.Generic;
  3. using System.ComponentModel.DataAnnotations;
  4. using System.ComponentModel.DataAnnotations.Schema;
  5. using System.Data.Entity;
  6. using System.Linq;
  7. using System.Text;
  8. using System.Threading.Tasks;
  9. namespace ConsoleWebSocket.Models
  10. {
  11. [Table("BaseDevice")]
  12. public class BaseDevice
  13. {
  14. [Key]
  15. public int Id { get; set; }
  16. public string Name { get; set; }
  17. public string Description { get; set; }
  18. }
  19. public class BaseDeviceDbContext : DbContext
  20. {
  21. public BaseDeviceDbContext()
  22. : base("myConn")
  23. {
  24. Database.SetInitializer(new DropCreateDatabaseIfModelChanges<BaseDeviceDbContext>());
  25. }
  26. public DbSet<BaseDevice> BaseDevice { get; set; }
  27. }
  28. }

4.操作数据库 测试

  1. /// <summary>
  2. /// code first
  3. /// </summary>
  4. public static void TestCodeFirst()
  5. {
  6. using (var context = new BaseDeviceDbContext())
  7. {
  8. // 查询数据
  9. List<BaseDevice> models = context.BaseDevice.ToList();
  10. // 添加数据
  11. context.BaseDevice.Add(new BaseDevice { Id = 1, Name = "New Model", Description= "Description" });
  12. context.BaseDevice.Add(new BaseDevice { Id = 3, Name = "New Model", Description = "Description" });
  13. context.SaveChanges();
  14. //// 更新数据
  15. var model = context.BaseDevice.FirstOrDefault(m => m.Id == 1);
  16. if (model != null)
  17. {
  18. model.Name = "Updated Name";
  19. context.SaveChanges();
  20. }
  21. // 删除数据
  22. context.BaseDevice.Remove(model);
  23. context.SaveChanges();
  24. }
  25. }

 

原文链接:https://www.cnblogs.com/motion/p/18281201

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号