我将 EF 5.0 (CodeFirst) 与 VS 2012 一起使用,并且无法使用 SqlQuery 进行查询。问题发生在实体的属性名称和数据库中列的名称之间的映射中。
我的实体(模型):
[Table("Teste")]
public class TesteEntity
{
[Column("Teste_Id")]
public int Id { get; set; }
[Required]
public bool IsAdministrator { get; set; }
[Required]
public string Name { get; set; }
}
当我运行查询时,我得到一个错误。
罗廷:
List<TesteEntity> list = dataContext.Database.SqlQuery<TesteEntity>("SELECT * FROM Teste").ToList();
错误:
The data reader is incompatible with the specified '....TesteEntity'. A member of the type, 'Id', does not have a corresponding column in the data reader with the same name.
数据库中的表结构:
CREATE TABLE [dbo].[Teste]( [Id] [int] IDENTITY(1,1) NOT NULL,
[IsAdministrator] [bit] NOT NULL, [Name] [nvarchar](max) COLLATE
Latin1_General_CI_AS NOT NULL, CONSTRAINT [PK_dbo.Teste] PRIMARY KEY
CLUSTERED ( [Id] ASC )WITH (PAD_INDEX = OFF, IGNORE_DUP_KEY = OFF)
ON [PRIMARY] ) ON [PRIMARY]
显然,当我使用 DataAnnotation [Column ("Teste_Id")] 并重新创建表时,一切正常,但想知道您是否必须使用 DataAnnotation [Column ("Teste_Id")] 执行此查询。
谢谢