- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我应该以免责声明作为开头,声明我是 ASP.NET 开发的新手,并不真正了解数据库上下文,尽管我花了最后一个小时阅读了文档。当我构建我的 ASP.NET MVC 5 应用程序时,我选择了个人用户帐户身份验证。 Visual Studio 创建了一个名为 IdentityModels.cs
的文件,并在其中定义了一个 ApplicationUser
类和一个ApplicationDbContext
类。
我做了一些开发工作,我的 CRUD Controller 使用 ApplicationDbContext
通过在每个 Controller 上拥有这个私有(private)属性来与数据库对话:
private ApplicationDbContext db = new ApplicationDbContext();
然后在 Controller 操作中,我会执行以下操作:
return View(db.Trains.ToList());
我想整理这个数据库上下文,但我需要先了解它。我的主要问题是:
ApplicationDbContext
吗? IdentityModels.cs
中定义的类和我自己的?ApplicationDbContext
类派生自 IdentityDbContext<ApplicationUser>
,这是否意味着我应该为 Visual Studio 提供的用户身份验证内容和我自己的代码使用单独的数据库上下文?我认为我的最终目标是使用我自己的数据库上下文,称为 DatabaseContext
,然后在我的所有 Controller 继承自的基本 Controller 中使用。然后我只有一个实例化数据库上下文的地方,而不是在每个 Controller 中。
谁知道呢,我可能想错了。每个人似乎都有自己喜欢的处理方式。
谢谢!
最佳答案
Is it okay to use just one database context for my entire application, like I'm doing now?
ApplicationDbContext
是您的 Controller 的私有(private)字段, Controller 是根据请求创建和处理的 - ApplicationDbContext
将根据请求创建和处置。Can I replace the ApplicationDbContext class defined in IdentityModels.cs with my own?
UserStore
接收 DbContext
作为构造函数中的参数,所以这个 var manager = new ApplicationUserManager(new UserStore<ApplicationUser>(new CustomDbContext("connection")));
会起作用。您仍然必须确保 ApplicationUser
是您自定义上下文中的一个实体。当然你可以覆盖/替换 ApplicationUser
The ApplicationDbContext class derives from IdentityDbContext, does that mean I should have seperate database contexts for my user authentication stuff provided by Visual Studio, and my own code?
默认情况下,Asp.Net Identity 会为您和 ApplicationDbContext
生成一个新的数据库配置为使用此数据库。您也可以将与身份验证相关的实体存储在任何其他数据库中,您只需要确保所有相关表都在那里。您还可以扩展此数据库以包含您在应用程序中使用的其他表,这样您就可以全部使用相同的上下文。
附注: ApplicationDbContext
不必实现 IdentityDbContext<ApplicationUser>
, 扩展默认 DbContext
也可以正常工作(如果您已经生成了 Db,则必须对其进行更新\使用代码迁移才能使以下内容正常工作):
public class ApplicationDbContext : DbContext
{
public ApplicationDbContext()
: base("DefaultConnection")
{
}
public static ApplicationDbContext Create()
{
return new ApplicationDbContext();
}
}
关于c# - 替换自动创建的 ApplicationDbContext,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28010113/
我想对一个字符串执行搜索和替换,比如 password。 正如您从问题中了解到的那样,替换后的字符串应变为 sdvvzrug。 但不幸的是,下面的代码输出bbbbcaab: $search = ran
我正在使用 futurize --stage2它应用了许多源代码转换以使代码 python2 和 python3 兼容。其中一个修复是所有分区 a/b 都替换为 old_div(a/b),我想避免这种
我正在使用 RStudio,但我在控制台上的输出被截断了。我找不到如何停止截断(我尝试搜索 ?options 以及在谷歌上搜索的时间比我想承认的要长)。 编辑:我向大家道歉!我最初的长名称为“This
我有一个 fragment 堆栈,我在其中使用替换和相加。添加或替换我的 fragment 的代码(在我的 Activity 中)如下 private fun addFragment(fragment
我在一个数组中插入了一些字符串,但在我这样做之前,我想按照主题所说的去做。只用 %20 替换空格,我这样做: Name.push(linkText.replace(" ", "%20")); 但是我如
我正在尝试编译和测试我在网上看到的代码 Expanding an IP add 。但是,当我尝试编译它时,我收到有关 StringBuilder 替换方法的错误。它说: IPadd.java:52:
我正在尝试使用 dplyr 的最新功能重写我的部分代码,方法是将 data.frame() 替换为 data_frame() 和 cbind() 与 bind_cols(): library(rgeo
我最近偶然发现了 replace()和 "[ x.tst s.tst s.tst [,1] [,2] [,3] [1,] 0 0 0
我一直想知道,如何在给定的参数内进行替换。 如果你有这样的一行: 123,Hello,World,(I am, here), unknown 你想更换 World与 Foobar那么这是一个简单的任务
如何转义字符串中的双引号?例如, input: "Nobody" output: \"Nobody\" 我尝试过这样的操作,但不起作用: String name = "Nobody"; name.r
我正在做类似的事情: SQL sql sQl SqL var ps = document.getElementsByTagName('p'); for(var i = 0; i 但它不会替换文本。
我正在尝试用 \" 替换所有 " 并用 JSON 解析字符串,但浏览器抛出错误 SyntaxError: JSON Parse error: Unrecognized token '\'. 下面是代码
大家好,在这里挣扎...... 是否可以将第一个正斜杠之间的任何内容替换为“”,但保留其余部分? 例如var 将是 string "/anything-here-this-needs-to-be-re
在下面的代码中,JavaScript 替换函数中的 alert(a) 将提醒匹配的字符串,在本例中,将是 {name} 和 {place}。 这按照文档 javascript docs 的描述工作,即
+-----------------------------+ | tables | +-------------------
我正在尝试用\"替换包含 "的字符串,下面是我尝试过的程序 String s="\"/test /string\""; s = s.replaceAll("\"", "\\\"");
var text = "a's ..a's ...\"... "; text = convert(text); function convert( text ) { var n = text
我正在尝试使用 JavaScript 中的替换函数,但有一个问题。 strNewDdlVolCannRegion = strNewDdlVolCannRegion.replace(/_existing
好吧,首先我对我的上一篇文章感到非常抱歉,但我真的需要帮助,我会把我真正想要的东西放在一个更清晰的代码中。我不擅长 javascript,所以希望你能帮助我。
我正在写一张纸条,遇到了障碍。可能有更有效的方法来执行此操作,但我对 Python 还很陌生。我正在尝试创建用户生成的 IP 地址列表。我正在使用 print 来查看生成的值是否正确。当我运行此代码时
我是一名优秀的程序员,十分优秀!