原文:Working with SQL Server LocalDB
作者:Rick Anderson
翻译: 魏美娟(初见)
校对: 孟帅洋(书缘)、张硕(Apple)、许登洋(Seay)

ApplicationDbContext 类负责连接数据库并将 Movie 对象和数据记录进行映射。 Startup.cs 文件中,数据库上下文是在 ConfigureServices 方法中用 Dependency Injection 容器进行注册的。

// This method gets called by the runtime. Use this method to add services to the container.
public void ConfigureServices(IServiceCollection services)
{// Add framework services.services.AddDbContext<ApplicationDbContext>(options => //手动高亮options.UseSqlServer(Configuration.GetConnectionString("DefaultConnection"))); //手动高亮

ASP.NET Core Configuration 系统读取 ConnectionString 。在本地开发模式下,它会从 appsettings.json 文件中获取连接字符串。

{"ConnectionStrings": {"DefaultConnection": "Server=(localdb)\\mssqllocaldb;Database=aspnet-MvcMovie-7db2893b-375e-48bd-86a3-bb9779b72ebe;Trusted_Connection=True;MultipleActiveResultSets=true" //手动高亮},"Logging": {"IncludeScopes": false,

当你部署应用程序到测试服务器或者生产服务器时,你可以使用环境变量或者另一种方法来设置实际 SQL Server 数据库的连接字符串。更多参考 Configuration 。

SQL Server Express LocalDB

LocalDB是针对程序开发阶段使用的一个SQL Server Express轻量级版本的数据库引擎。 因为LocalDB在用户模式下启动、执行,所以它没有复杂的配置。默认情况下,LocalDB数据库创建的 “*.mdf” 文件在 C:/Users/<user> 目录下。

View 菜单中,打开SQL Server对象资源管理器SQL Server Object Explorer ,(SSOX)).


右击 Movie 表 > 视图设计器(View Designer)


注意钥匙图标后面的 ID。默认情况下,EF将命名为 ID 的属性作为主键。

  • 右击 Movie> 查看数据(View Data)

填充数据库

Models 文件夹中创建一个名叫 SeedData 的新类。用以下代码替换生成的代码。

using Microsoft.EntityFrameworkCore;
using Microsoft.Extensions.DependencyInjection;
using MvcMovie.Data;
using System;
using System.Linq;namespace MvcMovie.Models
{public static class SeedData{public static void Initialize(IServiceProvider serviceProvider){using (var context = new ApplicationDbContext(serviceProvider.GetRequiredService<DbContextOptions<ApplicationDbContext>>())){if (context.Movie.Any()){return;   // DB has been seeded}context.Movie.AddRange(new Movie{Title = "When Harry Met Sally",ReleaseDate = DateTime.Parse("1989-1-11"),Genre = "Romantic Comedy",Price = 7.99M},new Movie{Title = "Ghostbusters ",ReleaseDate = DateTime.Parse("1984-3-13"),Genre = "Comedy",Price = 8.99M},new Movie{Title = "Ghostbusters 2",ReleaseDate = DateTime.Parse("1986-2-23"),Genre = "Comedy",Price = 9.99M},new Movie{Title = "Rio Bravo",ReleaseDate = DateTime.Parse("1959-4-15"),Genre = "Western",Price = 3.99M});context.SaveChanges();}}}
}

注意,如果数据库上下文中存在 movies,填充初始化器返回。

     if (context.Movie.Any()){return;   // DB has been seeded //手动高亮}

Startup.cs 文件中的 Configure 方法最后添加填充初始化器。

    app.UseMvc(routes =>{routes.MapRoute(name: "default",template: "{controller=Home}/{action=Index}/{id?}");});SeedData.Initialize(app.ApplicationServices); //手动高亮
}

测试应用程序

  • 删除数据库中的所有记录。你可以直接在浏览器中点击删除链接或者在 SSOX(SQL Server对象资源管理器)中做这件事。
  • 强制应用程序初始化(在 Startup 类中调用方法),这样填充方法会自动运行。为了强制初始化,IIS Express必须先停止,然后重新启动。可以用下列的任何一个方法来实现:

注意
如果是数据库没有初始化,在 if (context.Movie.Any()) 这行设置断点,并开始调试


应用程序显示了被填充的数据.

返回目录

转载于:https://www.cnblogs.com/dotNETCoreSG/p/aspnetcore-2_4_5-working-with-sql.html

ASP.NET Core 中文文档 第二章 指南(4.5)使用 SQL Server LocalDB相关推荐

  1. ASP.NET Core 中文文档 第二章 指南(4.4)添加 Model

    原文:Adding a model 作者:Rick Anderson 翻译:娄宇(Lyrics) 校对:许登洋(Seay).孟帅洋(书缘).姚阿勇(Mr.Yao).夏申斌 在这一节里,你将添加一些类来 ...

  2. ASP.NET Core 中文文档 第二章 指南(4.10)检查自动生成的Detail方法和Delete方法

    原文 Examining the Details and Delete methods 作者 Rick Anderson 翻译 谢炀(Kiler) 校对 许登洋(Seay).姚阿勇(Mr.Yao) 打 ...

  3. ASP.NET Core 中文文档 第二章 指南(4.3)添加 View

    原文:Adding a view 作者:Rick Anderson 翻译:魏美娟(初见) 校对:赵亮(悲梦).高嵩(Jack).娄宇(Lyrics).许登洋(Seay).姚阿勇(Dr.Yao) 本节将 ...

  4. ASP.NET Core 中文文档 第一章 入门

    原文:Getting Started 翻译:娄宇(Lyrics) 校对:刘怡(AlexLEWIS) 1.安装 .NET Core 2.创建一个新的 .NET Core 项目: mkdir aspnet ...

  5. ASP.NET Core 中文文档 第三章 原理(5)错误处理

    原文:Error Handling 作者:Steve Smith 翻译:谢炀(Kiler) 校对:高嵩(jack2gs).何镇汐 当你的ASP.NET应用发生错误的时候, 你可以采用本文所述的各种方法 ...

  6. ASP.NET Core 中文文档 第三章 原理(3)静态文件处理

    原文:Working with Static Files 作者:Rick Anderson 翻译:刘怡(AlexLEWIS) 校对:谢炀(kiler398).许登洋(Seay).孟帅洋(书缘) 静态文 ...

  7. ASP.NET Core中使用GraphQL - 第二章 中间件

    前文:ASP.NET Core中使用GraphQL - 第一章 Hello World 中间件 如果你熟悉ASP.NET Core的中间件,你可能会注意到之前的博客中我们已经使用了一个中间件, 这个中 ...

  8. ASP.NET Core 中文文档 第三章 原理(1)应用程序启动

    原文:Application Startup 作者:Steve Smith 翻译:刘怡(AlexLEWIS) 校对:谢炀(kiler398).许登洋(Seay) ASP.NET Core 为你的应用程 ...

  9. ASP.NET Core 中文文档 第三章 原理(13)管理应用程序状态

    原文:Managing Application State 作者:Steve Smith 翻译:姚阿勇(Dr.Yao) 校对:高嵩 在 ASP.NET Core 中,有多种途径可以对应用程序的状态进行 ...

最新文章

  1. C++ 笔记 2 (C++ primer)
  2. 《OKR源于英特尔和谷歌的目标管理利器》读书笔记
  3. DOS命令大全(一)
  4. Xcode7将无需开发者授权也能在真机上调试App
  5. Jerry开发的SAP note工具
  6. 工业以太网交换机的接口知识详解
  7. treeselect只选了分支节点全选_vue Treeselect 树形下拉框:获取选中节点的ids和lables操作...
  8. C#LeetCode刷题之#441-排列硬币(Arranging Coins)
  9. gitlab导入本地项目_Gitlab使用心得
  10. html5 content type,Content-Type一览
  11. linux mask 特殊权限位,Linux 特殊权限
  12. 每天多采一半油!中东联手中国阿里云的研究有望降低国际油价
  13. HTTP API 设计指南
  14. java单例模式使用_Java单例模式的应用
  15. delphi 运算符
  16. 781.森林中的兔子
  17. linux 3.0实时性,如何1分钟内对 Linux 性能快速分析(113资讯网)
  18. 如何用python编写财务记账软件_Python实现简单的记账本功能
  19. pandas等导入excel后 日期时间无法直接运算的问题 (str转datetime的方法)
  20. 集合框架|Java集合框架基本使用

热门文章

  1. spring14:注解@Autowired,实现引用类型的赋值
  2. Python学习教程(Python学习路线):Python3之递归函数简单示例
  3. 开发vue底部导航栏组件
  4. 《游戏力》读书笔记作文4700字
  5. 史上最全!图解浏览器的工作原理
  6. Android IOS WebRTC 音视频开发总结(四二)-- webrtc开发者大会
  7. 使用JavaScript动态添加复选框Checkbox
  8. ThinkPHP 框架培训资料
  9. C#自定义控件一下拉颜色框
  10. 三种运动让身高增长4-10cm