CSharp: donet 7 create database view mapping with EF core 7.02
sql:
1 2 3 4 5 | create view ViewEmployeeMasters as select a.*,b. Name as 'DepartmentName' ,b.Code as 'DepartmentCode' from EmployeeMasters as a,DepartmentMaster as b where a.DepartmentId=b.DepartmentId go |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 | /// <summary> /// 视图 /// Create A Database View Using The Entity Framework (EF) Code First Approach /// </summary> public class ViewEmployeeMasters { public int EmployeeId { get; set ; } /// <summary> /// /// </summary> public string Code { get; set ; } /// <summary> /// /// </summary> public string Name { get; set ; } /// <summary> /// /// </summary> public int DepartmentId { get; set ; } /// <summary> /// /// </summary> public string DepartmentCode { get; set ; } /// <summary> /// /// </summary> public string DepartmentName { get; set ; } /// <summary> } /// <summary> /// 视图 /// </summary> public DbSet<ViewEmployeeMasters> ViewEmployeeMasters { get; set ; } /// <summary> /// /// </summary> /// <param name = "optionsBuilder" ></param> protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder) { //读取配置文件 var config = new ConfigurationBuilder() .SetBasePath(Directory.GetCurrentDirectory()) //Environment.CurrentDirectory .AddJsonFile( "appsettings.json" ) .AddInMemoryCollection() .Build(); var connStr = config[ "ConnectionStrings:GeovinDuDbContext" ]; // optionsBuilder.UseSqlServer( "Server=DESKTOP-NQK85G5\\GEOVIN2008;Database=geovindu;User Id=sa;Password=geovindu;" ); optionsBuilder.UseSqlServer(connStr); } /// <summary> /// https://learn.microsoft.com/en-us/ef/core/what- is -new/ef-core-7.0/whatsnew /// 存储过程映射 /// Stored procedure mapping /// </summary> /// <param name = "modelBuilder" ></param> protected override void OnModelCreating(ModelBuilder modelBuilder) { modelBuilder.Entity<DuProduct>(); modelBuilder.Entity<DuCustomer>(); modelBuilder.Entity<People>(); modelBuilder.Entity<ViewEmployeeMasters>().ToView( "ViewEmployeeMasters" ) .HasNoKey(); } |
调用:
1 2 3 4 5 6 7 8 9 10 | DuDbContext context = new DuDbContext(); var viewEmployeeMasters = context.ViewEmployeeMasters .Where(po => po.EmployeeId < 10) .ToList(); foreach (ViewEmployeeMasters em in viewEmployeeMasters) { Console.WriteLine(em.Name+ " 视图查询" ); } |
输出:
1 2 3 4 | Security Warning: The negotiated TLS 1.0 is an insecure protocol and is supported for backward compatibility only. The recommended protocol version is TLS 1.2 and later. 涂聚文 视图查询 ok edit,ok |
哲学管理(学)人生, 文学艺术生活, 自动(计算机学)物理(学)工作, 生物(学)化学逆境, 历史(学)测绘(学)时间, 经济(学)数学金钱(理财), 心理(学)医学情绪, 诗词美容情感, 美学建筑(学)家园, 解构建构(分析)整合学习, 智商情商(IQ、EQ)运筹(学)生存.---Geovin Du(涂聚文)
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 零经验选手,Compose 一天开发一款小游戏!
· 一起来玩mcp_server_sqlite,让AI帮你做增删改查!!
2015-02-07 csharp:search and Compare string
2009-02-07 C#2.0 print winform 打印窗体数据试试