tnblog
首页
视频
资源
登录

NET Core 之EF CodeFirst的创建

4274人阅读 2019/12/24 15:46 总访问:38528 评论:2 收藏:0 手机
分类: Net Core

                 

  1. 第一步: 找到appsettings.json这个文件,修改如下:
  2. {
  3.   "Logging": {
  4.     "LogLevel": {
  5.       "Default""Warning"
  6.     }
  7.   },
  8.   "AllowedHosts""*",
  9.   "ConnectionStrings": {
  10.     "BloggingDatabase""Server=.;Database=数据库名称;Trusted_Connection=True;"
  11.   }
  12. }
  13. 第二步: 创建一个类继承DbContext,
  14. using Microsoft.EntityFrameworkCore;
  15. using Model;
  16. using System;
  17. using System.Collections.Generic;
  18. using System.Linq;
  19. using System.Reflection;
  20. using System.Text;
  21. namespace DAL
  22. {
  23.     public class CoreFirst_DbContextDbContext
  24.     {
  25.         public CoreFirst_DbContext(DbContextOptions<CoreFirst_DbContext> options) : base(options)
  26.         {
  27.         }
  28.         public DbSet<Post> Posts { getset; }
  29.         public DbSet<Tag> Tags { getset; }
  30.         protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)
  31.         {
  32.             base.OnConfiguring(optionsBuilder);
  33.         }
  34.         protected override void OnModelCreating(ModelBuilder modelBuilder)
  35.         {
  36.             //唯一约束,替代键
  37.             modelBuilder.Entity<PostTag>()
  38.                 .HasKey(pt => new { pt.PostId, pt.TagId });
  39.             modelBuilder.Entity<PostTag>()
  40.                 .HasOne(pt => pt.Post)
  41.                 .WithMany(p => p.PostTags)
  42.                 .HasForeignKey(pt => pt.PostId);
  43.             modelBuilder.Entity<PostTag>()
  44.                 .HasOne(pt => pt.Tag)
  45.                 .WithMany(t => t.PostTags)
  46.                 .HasForeignKey(pt => pt.TagId);
  47.         }
  48.     }
  49.     public class Post
  50.     {
  51.         public int PostId { getset; }
  52.         public string Title { getset; }
  53.         public string Content { getset; }
  54.         public List<PostTag> PostTags { getset; }
  55.     }
  56.     public class Tag
  57.     {
  58.         public int TagId { getset; }
  59.         public string remark { getset; }
  60.         public List<PostTag> PostTags { getset; }
  61.     }
  62.     public class PostTag
  63.     {
  64.         public int PostId { getset; }
  65.         public Post Post { getset; }
  66.         public int TagId { getset; }
  67.         public Tag Tag { getset; }
  68.     }
  69. }
  70. 第三步:找到Startup.cs这个文件,找到它下面的ConfigureServices方法并添加
  71. services.AddDbContext<CoreFirst_DbContext>(options =>
  72.                      options.UseSqlServer(Configuration.GetConnectionString("BloggingDatabase")));
  73. 第四步:然后添加数据迁移,更新数据库,就完成了多对多关系数据库的配置。


评价

剑轩

2019/12/24 16:48:58

可以可以,[兔子][兔子]其实代码和文字分开贴更科学一点哦

皮卡丘:@剑轩下次注意哈

2019/12/25 14:38:12 回复

net core 使用 EF Code First

下面这些内容很老了看这篇:https://www.tnblog.net/aojiancc2/article/details/5365 项目使用多层,把数据库访问...

.net mvc分部页,.net core分部页

.net分部页的三种方式第一种:@Html.Partial(&quot;_分部页&quot;)第二种:@{ Html.RenderPartial(&quot;分部页&quot;);}...

StackExchange.Redis操作redis(net core支持)

官方git开源地址https://github.com/StackExchange/StackExchange.Redis官方文档在docs里边都是官方的文档通过nuget命令下...

.net core 使用session

tip:net core 2.2后可以直接启用session了,不用在自己添加一次session依赖,本身就添加了使用nuget添加引用Microsoft.AspN...

通俗易懂,什么是.net?什么是.net Framework?什么是.net core?

朋友圈@蓝羽 看到一篇文章写的太详细太通俗了,搬过来细细看完,保证你对.NET有个新的认识理解原文地址:https://www.cnblo...

asp.net core2.0 依赖注入 AddTransient与AddScoped的区别

asp.net core主要提供了三种依赖注入的方式其中AddTransient与AddSingleton比较好区别AddTransient瞬时模式:每次都获取一...

.net core 使用 Kestrel

Kestrel介绍 Kestrel是一个基于libuv的跨平台web服务器 在.net core项目中就可以不一定要发布在iis下面了Kestrel体验可以使...

net core中使用cookie

net core中可以使用传统的cookie也可以使用加密的cookieNET CORE中使用传统cookie设置:HttpContext.Response.Cookies.Appe...

net core项目结构简单分析

一:wwwrootwwwroot用于存放网站的静态资源,例如css,js,图片与相关的前端插件等lib主要是第三方的插件,例如微软默认引用...

net core使用EFDB First

一.新建一个.net core的MVC项目新建好项目后,不能像以前一样直接在新建项中添加ef了,需要用命令在添加ef的依赖二.使用Nug...

.net core使用requestresponse下载文件下载excel等

使用request获取内容net core中request没有直接的索引方法,需要点里边的Query,或者formstringbase64=Request.Form[&quot;f...

iframe自适应高度与配合net core使用

去掉iframe边框frameborder=&quot;0&quot;去掉滚动条scrolling=&quot;no&quot;iframe 自适应高度如果内容是固定的,那么就...

net core启动报错Unable to configure HTTPS endpoint. No server certificate was specified

这是因为net core2.1默认使用的https,如果使用Kestrel web服务器的话没有安装证书就会报这个错其实仔细看他的错误提示,其...

net core中使用url编码与解码操作

net core中暂时还没有以前asp.net与mvc中的server对象。获取url的编码与解码操作不能使用以前的server对象来获取。使用的是...

下载net core

官方下载地址:https://dotnet.microsoft.com/download 进来之后就可以看到最新的下载版本可以直接点击下载,也可以下载其...

net core使用依赖注入来装载EF的上下文对象

妹子情人节快乐~.net core中用了不少的依赖注入,官方文档中也推荐使用。这样使用依赖注入来管理ef对象,还是比较科学,比如...
一电照耀十四洲,电来!
排名
53
文章
11
粉丝
5
评论
9
ICP备案 :渝ICP备18016597号-1
网站信息:2018-2025TNBLOG.NET
技术交流:群号656732739
联系我们:contact@tnblog.net
公网安备:50010702506256
欢迎加群交流技术
故友的灵魂,能交给我吗?