gpt4 book ai didi

mysql - SetInitializer用于数据库错误

转载 作者:行者123 更新时间:2023-11-29 13:14:51 25 4
gpt4 key购买 nike

我正在尝试转换示例 ASP.Net 帖子; ASP.NET Identity:将 MySQL 存储与 EntityFramework MySQL 提供程序结合使用 (C#) Project found here

以下代码来自示例

 public class ApplicationDbContext : IdentityDbContext<ApplicationUser>
{
static ApplicationDbContext()
{
Database.SetInitializer(new MySqlInitializer());
}

public ApplicationDbContext()
: base("DefaultConnection")
{
}
}

这将转换为 vb.net,如下所示

Public Class ApplicationDbContext
Inherits IdentityDbContext(Of ApplicationUser)
Shared Sub New()
'the code is erring here on the next line
Database.SetInitializer(New MySqlInitializer())
End Sub

Public Sub New()
MyBase.New("DefaultConnection")
End Sub

下课

初始化类如下

Public Class MySqlInitializer
Implements IDatabaseInitializer(Of ApplicationDbContext)

Public Sub InitializeDatabase(context As ApplicationDbContext) Implements IDatabaseInitializer(Of ApplicationDbContext).InitializeDatabase
If Not context.Database.Exists() Then
context.Database.Create()
Else

Dim migrationHistoryTableExists = DirectCast(context, IObjectContextAdapter).ObjectContext.ExecuteStoreQuery(Of Integer)(String.Format("SELECT COUNT(*) FROM information_schema.tables WHERE table_schema = '{0}' AND table_name = '__MigrationHistory'","connstring"))

If migrationHistoryTableExists.FirstOrDefault() = 0 Then
context.Database.Delete()
context.Database.Create()
End If
End If
End Sub

Database.SetInitializer(New MySqlInitializer()) 代码行中的代码出错

错误 31262 如果没有类的显式实例,则无法从共享方法或共享成员初始值设定项中引用类的实例成员。 C:\WebAppTemplate\AspNetIdentityTemplate_MySql\AspNetIdentityTemplate_MySql\Models\IdentityModels.vb 14 9 AspNetIdentityTemplate_MySql

数据库下 DataBase.SetInitializer 行中的蓝色波浪线...

我所有的纠正尝试都会导致相同或其他错误。任何帮助表示赞赏。

最佳答案

该帖子的一个代码示例中存在错误。

突出显示的行对应于该 string.Format 方法的参数,但是该参数应该是数据库架构名称,而不是连接字符串。

如果您有一个名为 users 的数据库,那么您应该在此处指定“users”

enter image description here enter image description here

关于mysql - SetInitializer用于数据库错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21607008/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com