asp.net mvc-如何创建一个在C#mvc中两次引用另一个模型的代码优先模型

本文关键字:模型 引用 两次 另一个 代码 何创建 mvc- net 创建 asp 一个 | 更新日期: 2023-09-27 17:57:27

我正在尝试了解如何使用代码优先的方法来实现这一点。早在以前,我就知道如何使用SQL语句和ASP编写更多代码。现在我试着用C#中的代码优先MVC方法来教自己如何理解它。

首先,如果我要解释我在SQL中想要什么,我希望复制这样的东西。

    Select s1.systemname, s2.systemname, j,jumplaneid 
    from systems s1, systems s2, jumplanes j 
    where s1.systemid = j.system1id and s2.systemid = j.system2id

这是我的系统模型。

    public class system
    {
    public virtual int systemid { get; set; }
    public virtual string systemname { get; set; }
    public virtual int? posx { get; set; }
    public virtual int? posy { get; set; }
    public virtual int? starluminosityid { get; set; }
    public virtual int? stellartypeid { get; set; }
    public virtual int? starspectralclassid { get; set; }
    public virtual int? carry { get; set; }
    public virtual int? raw { get; set; }
    public virtual int? bio { get; set; }
    public virtual int? jumppoints { get; set; }
    public virtual int? specialrolls { get; set; }
    public virtual ICollection<settlement> settlements { get; set; }
    public virtual ICollection<fleet> fleets { get; set; }
    public virtual ICollection<Jumplane> jumplanes { get; set; }
    public virtual stellartype Stellartype { get; set; }
    public virtual starluminosity Luminosity { get; set; }
    public virtual starspectralclass SpectralClass { get; set; }
}

我正在尝试创建一个跨平台模型,该模型将引用端点的系统模型。我把它设置成这样,我认为这很接近,但并不完全到位。想法?

public class Jumplane
{
    public virtual int jumplaneid { get; set; }
    public virtual int jumpcost { get; set; }
    public virtual string jumplanename { get; set; }
    public virtual system system1 { get; set; }
    public virtual system system2 { get; set; }
    public virtual ICollection<Supplyline> supplylines { get; set; }
}

当我执行"更新数据库"以在数据库中设置所有内容时,我会得到一个如下所示的跟踪:

    PM> update-database -force
    Specify the '-Verbose' flag to view the SQL statements being applied to the target database.
    No pending code-based migrations.
    Applying automatic migration: 201302030335260_AutomaticMigration.
    System.Data.SqlClient.SqlException (0x80131904): Either the parameter @objname is     ambiguous or the claimed @objtype (COLUMN) is wrong.
      at System.Data.SqlClient.SqlConnection.OnError(SqlException exception, Boolean breakConnection, Action`1 wrapCloseInAction)
      at System.Data.SqlClient.SqlInternalConnection.OnError(SqlException exception, Boolean breakConnection, Action`1 wrapCloseInAction)
      at System.Data.SqlClient.TdsParser.ThrowExceptionAndWarning(TdsParserStateObject stateObj, Boolean callerHasConnectionLock, Boolean asyncClose)
      at System.Data.SqlClient.TdsParser.TryRun(RunBehavior runBehavior, SqlCommand cmdHandler, SqlDataReader dataStream, BulkCopySimpleResultSet bulkCopyHandler, TdsParserStateObject stateObj, Boolean& dataReady)
      at System.Data.SqlClient.SqlCommand.RunExecuteNonQueryTds(String methodName, Boolean async, Int32 timeout)
      at System.Data.SqlClient.SqlCommand.InternalExecuteNonQuery(TaskCompletionSource`1 completion, String methodName, Boolean sendToPipe, Int32 timeout, Boolean asyncWrite)
      at System.Data.SqlClient.SqlCommand.ExecuteNonQuery()
      at System.Data.Entity.Migrations.DbMigrator.ExecuteSql(DbTransaction transaction, MigrationStatement migrationStatement)
      at System.Data.Entity.Migrations.Infrastructure.MigratorLoggingDecorator.ExecuteSql(DbTransaction transaction, MigrationStatement migrationStatement)
      at System.Data.Entity.Migrations.DbMigrator.ExecuteStatements(IEnumerable`1 migrationStatements)
      at System.Data.Entity.Migrations.Infrastructure.MigratorBase.ExecuteStatements(IEnumerable`1 migrationStatements)
      at System.Data.Entity.Migrations.DbMigrator.ExecuteOperations(String migrationId, XDocument targetModel, IEnumerable`1 operations, Boolean downgrading, Boolean auto)
      at System.Data.Entity.Migrations.DbMigrator.AutoMigrate(String migrationId, XDocument sourceModel, XDocument targetModel, Boolean downgrading)
      at System.Data.Entity.Migrations.Infrastructure.MigratorLoggingDecorator.AutoMigrate(String migrationId, XDocument sourceModel, XDocument targetModel, Boolean downgrading)
      at System.Data.Entity.Migrations.DbMigrator.Upgrade(IEnumerable`1 pendingMigrations, String targetMigrationId, String lastMigrationId)
      at System.Data.Entity.Migrations.Infrastructure.MigratorLoggingDecorator.Upgrade(IEnumerable`1 pendingMigrations, String targetMigrationId, String lastMigrationId)
      at System.Data.Entity.Migrations.DbMigrator.Update(String targetMigration)
      at System.Data.Entity.Migrations.Infrastructure.MigratorBase.Update(String targetMigration)
      at System.Data.Entity.Migrations.Design.ToolingFacade.UpdateRunner.RunCore()
      at System.Data.Entity.Migrations.Design.ToolingFacade.BaseRunner.Run()
    ClientConnectionId:c4c1ba62-806b-4e68-bb0b-161da4d9e23e
    Either the parameter @objname is ambiguous or the claimed @objtype (COLUMN) is wrong.

如果我先建立数据库,我知道如何做到这一点,但我正在尝试学习代码优先的方法。有谁更熟悉软件开发的当前趋势,能给我一个指导吗?

谢谢!

更新:感谢你们,从你们每个人身上学到了一些东西

这就是我的归宿。

    public class Jumplane
{
    [Key]
    public int jumplaneid { get; set; }      
    [Range (1,1000)]
    public decimal jumpcost { get; set; }
    [Required]
    [StringLength(30)]
    public string jumplanename { get; set; }
    public virtual Starsystem starsystem1 { get; set; }
    public virtual Starsystem starsystem2 { get; set; }
    public virtual ICollection<Supplyline> supplylines { get; set; }
}

public class Starsystem
{
    [Key]
    public int starsystemid { get; set; }
    public string systemname { get; set; }
    public int? posx { get; set; }
    public int? posy { get; set; }
    public int? starluminosityid { get; set; }
    public int? stellartypeid { get; set; }
    public int? starspectralclassid { get; set; }
    public int? carry { get; set; }
    public int? raw { get; set; }
    public int? bio { get; set; }
    public int? jumppoints { get; set; }
    public int? specialrolls { get; set; }
    public virtual ICollection<settlement> settlements { get; set; }
    public virtual ICollection<fleet> fleets { get; set; }
    public virtual ICollection<Jumplane> jumplanes { get; set; }
    public virtual stellartype Stellartype { get; set; }
    public virtual starluminosity Luminosity { get; set; }
    public virtual starspectralclass SpectralClass { get; set; }
}

我将返回并获取附加的注释。因为我的头都掉了,长满了尖尖的头发,我错过了注释的意义。

当你认为这是一个重命名问题时,我对更新数据库的问题就变得很清楚了。添加-Verbose选项让我很清楚。我可能作弊了,但我简化了模型,删除了其中的两个starsystem引用,更新了数据库,然后一个接一个地添加回来。

我也很欣赏代码审查类资本化和使用"虚拟"关键字。我确实在id和name上留下了更具描述性的前缀,但这主要是为了我,因为如果我去掉它们,我以后可能会感到困惑。由于代码只是为我准备的,我决定传递这条特定的建议,但反馈过去(现在)仍然是最受欢迎的。

再次感谢你们的时间和专业知识。

asp.net mvc-如何创建一个在C#mvc中两次引用另一个模型的代码优先模型

当您试图重命名表时,通常会出现此错误。

我有一个建议,让你创建你的模型,并尝试用尽可能少的字段来实现你想要的结果。此外,您希望仅在外部实体上使用virtual关键字。

我刚刚测试了一些类似的东西(Admin,AdminLog[Contains Admin1 and Admin2]),它运行得很好。

您应该尝试的代码

public class System
{
    public int ID { get; set; }
    public string Name { get; set; }
}
public class Jumplane
{
    public int ID { get; set; }
    public virtual System System1 { get; set; }
    public virtual System System2 { get; set; }
}

现在,这段代码可以工作了,您将能够执行所需的LINQ查询,只需将所有其他字段添加到其中即可。

一些指针(可能是主观的)

  • 仅限国外虚拟
  • 课程以大写字母开头
  • 不需要SystemIDSystemName字段,只需要IDName即可,因为您会看到它属于System

像您在EF中想要的查询一样的查询应该是dbContext.Jumplanes.Include("system1").Include("system2")

话虽如此,您的模型没有属性/注释,一切都是虚拟的。您只需要在希望延迟加载某个属性时将其设置为虚拟。元素的主键实际上不应该延迟加载。

查看KeyForeignKey属性,用它们注释模型,删除不需要的虚拟关键字,然后让我们知道它的进展:)