EF Core 2.1 +数据库视图


1.参考文档

https://stackoverflow.com/questions/36012616/working-with-sql-views-in-entity-framework-core

https://docs.microsoft.com/en-us/ef/core/modeling/query-types

Step 1:

首先数据库新建一个 View视图,咱们称之为"V_USer_FromHRM".

Step 2:

项目中新建一个Model 与视图查询结果相对应。

 1 public class V_HRMUser
 2  { 3 public V_HRMUser() 4  { 5 6  } 7 8 public string Empl_code { get; set; } 9 public string Sitecode { get; set; } 10 public string Department { get; set; } 11 public string Function { get; set; } 12 public string Position { get; set; } 13 14 15 }

 

Step3:

Dbconext中添加如下代码(涉及项目内容,代码有删减,看得明白就好):)

 1 public class DefaultDbContext : DbContext
 2  { 3 public DefaultDbContext(DbContextOptions<DefaultDbContext> options) : base(options) 4  { 5 6  } 7 8 9 10 public DbQuery<V_HRMUser> V_HRMUsers { get; set; } 11 12 13 14 protected override void OnModelCreating(ModelBuilder modelBuilder) 15  { 16 //不必太在意字段信息,涉及到项目内容,已经做了删改。 17 modelBuilder.Query<V_HRMUser>(v => { 18 v.ToView("V_USer_FromHRM"); 19 v.Property(p => p.Department).HasColumnName("department"); 20 v.Property(p => p.Empl_code).HasColumnName("empl_code"); 21 v.Property(p => p.EmpType).HasColumnName("emptype"); 22 v.Property(p => p.Ename).HasColumnName("ename"); 23 24 25 26  } 27  ); 28  } 29 30 }

 

Step 4:

测试结果:

随便找个 Controller ,

 public class HomeController : BaseController
    {
        private DefaultDbContext _context; public HomeController( DefaultDbContext context) { _context = context; var list = _context.V_HRMUsers.ToList(); } }

 

结果:

 

 

To DO

1.类型转换转换问题。

2.数据是只读的,有没有更好的读取方式? 

3.缓存?

 


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM