15

我有这两个实体:

public partial class Suscriptores
{
    public Suscriptores()
    {
       this.Publicacion = new HashSet<Publicacion>();
    }

    [Key]
    public int IdSuscriptor { get; set; }
    public string LogoSuscriptor { get; set; }
    public string Identificacion { get; set; }
    public string Nombre { get; set; }
    public string Direccion { get; set; }
    public string Telefono { get; set; }
    public string Email { get; set; }
    public string Fax { get; set; }
    public string Home { get; set; }

    public virtual ICollection<Publicacion> Publicacion { get; set; }
}

public partial class Publicacion
{
    public Publicacion()
    {
        this.Edictos = new HashSet<Edictos>();
    }

    [Key]
    public decimal IdPublicacion { get; set; }
    public System.DateTime FechaPublicacion { get; set; }
    public string IdUsuario { get; set; }
    public System.DateTime FechaPublicacionHasta { get; set; }
    public System.DateTime FechaArchivoHasta { get; set; }
    public int IdSuscriptor { get; set; }
    public decimal IdTipoPublicacion { get; set; }

    [ForeignKey("IdSuscriptor")]
    public virtual Suscriptores Suscriptores { get; set; }
}

当我尝试运行此查询时:

public ActionResult DetailsVSTO(string Identificacion)
{
    var SusQ = from s in db.Suscriptores
               where s.Identificacion == Identificacion
               select s;

    return Json(SusQ.First(), JsonRequestBehavior.AllowGet);
}

它抛出这个消息:

System.Data.SqlClient.SqlException:列名“Suscriptores_IdSuscriptor1”无效

为了解决这个问题,我在 DBContext 中添加了这个流畅的 API 代码:

modelBuilder.Entity<Suscriptores>()
    .HasMany(x => x.Publicacion)
    .WithRequired(x => x.Suscriptores)
    .Map(a => a.MapKey("IdSuscriptor"));

但问题仍然存在。我该如何解决这个问题?

4

5 回答 5

10

尝试添加多对一映射。请使用纯 Fluent API,您应该删除 [ForeignKey] 注释。

modelBuilder.Entity<Publicacion>()
            .HasRequired(x => x.Suscriptores)
            .WithMany(x => x.Publicacion);
于 2013-02-17T01:20:42.447 回答
9

我收到了与非外键列有关的此错误,并浪费了太多时间试图找出错误。它在我的代码中,而不是在 EF 或数据库中。我只是以为我输入了

this.Property(t => t.Revision).HasColumnName("Revision");
this.Property(t => t.DistributionClass).HasColumnName("DistributionClass");

但我输入的是

this.Property(t => t.Revision).HasColumnName("Revision");
this.Property(t => t.Revision).HasColumnName("DistributionClass");

我想我正在查看上面的行并放置t.Revision而不是t.DistributionClass. 无论我看了多久,我都看不到自己的错误。运气好的话,这将节省一些其他可怜的灵魂一些时间。

于 2014-03-06T17:27:32.813 回答
3

我在刚刚添加的属性(列)上的项目表中遇到了这个问题,真是令人沮丧!

原来我在 Order 的数据模型中有一个 List 属性,并且因为我没有在该配置中忽略它,所以它在 Item 表中导致了同样的问题。这不会发生,除非两个表都有同名的属性,所以我必须这样做......无论如何我都应该这样做。

public OrderConfiguration() { Ignore(p => p.Items); }

于 2015-10-09T23:21:24.960 回答
1

大家好 就我而言,我有一个遗留代码,其中包含两个具有相同外键的不同名称的类。添加注释对正确列的引用和其他类中具有相同名称的属性名称。然后注释ForeignKey在两列之间进行匹配。

[Table("LFile")]
public partial class LFile
{
    [Key]
    public int FileId { get; set; }

    [StringLength(500)]
    public string FileName { get; set; }

    public int? LRRFileDetailId { get; set; }

    public byte[] FileData { get; set; }

    public FileType Type { get; set; }

    [Column("LUpload_Id")] //Foreign Key of the class
    public int? LUploadId { get; set; }

    [ForeignKey("LUploadId")] //Foreign key inherited
    public virtual LParserProcess LParserProcess { get; set; }
}
于 2019-07-09T18:40:16.550 回答
1

我收到了相同的错误 SqlException 消息,其中数字 1 被附加到我的字段名称中。

一旦我意识到我错误地假设 [ForeignKey] 注释引用了数据库中的字段名称,我就能够解决它。相反,它们应该与模型中定义的属性名称相匹配。

例如:

[Column("Organisation_Account_Manager")]
[Display(Name = "Organisation_Account_Manager_ID")]
[DisplayFormat(NullDisplayText = "Unknown")]
public int? Organisation_Account_Manager_ID { get; set; }

[Display(Name = "Account Manager")]
[ForeignKey("Organisation_Account_Manager_ID")]
public Contact Account_Manager { get; set; }

在这个例子中它会起作用,因为 [ForeignKey("Organisation_Account_Manager_ID")] 与 public int 完全匹配?组织_帐户_经理_ID。以前我的 [ForeignKey] 注释使用的是 Organisation_Account_Manager,这是数据库中的字段名称 - 但这是不正确的。

于 2020-06-26T04:43:51.490 回答