EF 简单 增删改查

一、新建Models 中实体类

在类中添加特性,添加特性之前需要引用命名空间

using System.ComponentModel.DataAnnotations;
using System.ComponentModel.DataAnnotations.Schema;

1、类的上边 [Table("表名称")] ​ 2、主键 [Key]

[Table("Student")]
  public class Student
  {
      [Key]
      public int SId { get; set; }
      [Required(ErrorMessage ="请输入姓名")]
      [StringLength(50)]
      public string SName { get; set; }
  }

二、新建Dal文件夹

1、右键-》新建项-》左边点数据,右边点 ADO.NET 实体数据模型-》选择空Code First 模型

2、在实体数据模型当中 添加 数据集属性

public DbSet<Model实体类> 属性名 { get; set; }--格式
public DbSet<Student> Students { get; set; }--例

三、更改web.config 数据库连接字符串

1、更改connectionString属性名 data source 值 改成 .或数据库实例名称

2、更改connectionString属性名 initial catalog 值 改成 自定义数据库名称

四、完成数据迁移命令-》菜单点-》工具-》NuGet包管理器->程序包管理器控制台

 

1、Enable-Migrations 启动迁移(将自动生成的Configuration文件中 AutomaticMigrationsEnabled =true)允许自动迁移

2、add-Migration init (init 名称自定义)

3、update-database 完成更数据库 迁移操作

五、增删改查之前实例化上下文

//上下文
      Model1 db = new Model1();

六、添加

例子:
public int Add(Student stu)
      {
          db.Students.Add(stu);//更改状态为“添加”
          return db.SaveChanges();//受影响行数
      }

七、删除

public int Del(int id)
      {
          //先通过id查询
          var item= db.Students.Find(id);
          //删除(更改状态)
          db.Students.Remove(item);
          //操作数据库
          return db.SaveChanges();
      }

八、显示

public List<Student> show()
      {
          return db.Students.ToList();//将数据转换为List集合
      }

九、编辑

public Student FinById(int id)
      {
          return db.Students.Find(id);//按id查询
      }

 

十、修改

public int Edit(Student stu)
      {
      //将实体类的状态改为“修改”状态
          db.Entry(stu).State = System.Data.Entity.EntityState.Modified;
          //受影响行数
          return db.SaveChanges();
      }

 

上一篇:EF core 映射的数据转换——记RowVersion的读取


下一篇:EF Linq To Sql程序案例练习1(一看就懂)