'FromSql'操作の結果に必要な列が存在しませんでした

asp.net-core-mvc entity-framework-core

質問

私はEF7でMVC6を学習し始めました。私は、私のモデルにあるフィールドの一部を返すことを望むストアドプロシージャを持っています。私のモデルのすべてのフィールドを返さない場合は、 "FromSql '操作の結果に必要な列' FirstName 'が存在しませんでした。

私のモデルのフィールドの一部だけを返すことができるように、いくつかの列を必要としないようにする方法がありますか?

モデル:

public class LoginViewModel
{
    [Key]
    public int UserID { get; set; }

    [Required]
    [Display(Name = "Username")]
    public string Username { get; set; }

    [Required]
    [DataType(DataType.Password)]
    [Display(Name = "Password")]
    public string Password { get; set; }

    [Required]
    [DataType(DataType.Password)]
    [Display(Name = "Protected ID")]
    public string ProtectedID { get; set; }

    public string FirstName { get; set; }
    public string LastName { get; set; }
}

テストのための私のproc:

CREATE PROCEDURE [dbo].[aaa_TopXXUsersTest]
@NumToReturn int = 10
AS
BEGIN
    SET NOCOUNT ON;
    select top(@NumToReturn) UserID, LastName, Username,Password, ProtectedID from Users where Deleted = 0

END

最後に、私のコントローラコード:

public IActionResult Index()
{
    var user = _context.Set<LoginViewModel>().FromSql("dbo.aaa_TopXXUsersTest @NumToReturn = {0}", 20);

    return View(user);
}

ストアドプロシージャにモデルのすべてのフィールドを含めると、呼び出しは正常に機能しますが、サブセットのみを返すようには見えません。いくつかのフィールドを必要としないようにする方法はありますか?

人気のある回答

使用された[NotMapped]属性はファーストネームで使用されました。

NotMapped属性は、データベース内の対応する列を作成したくないエンティティクラスのプロパティに適用できます。

public class LoginViewModel
    {
        [Key]
        public int UserID { get; set; }

        [Required]
        [Display(Name = "Username")]
        public string Username { get; set; }

        [Required]
        [DataType(DataType.Password)]
        [Display(Name = "Password")]
        public string Password { get; set; }

        [Required]
        [DataType(DataType.Password)]
        [Display(Name = "Protected ID")]
        public string ProtectedID { get; set; }

        [NotMapped]
        public string FirstName { get; set; }

        public string LastName { get; set; }
    }


Related

ライセンスを受けた: CC-BY-SA with attribution
所属していない Stack Overflow
このKBは合法ですか? はい、理由を学ぶ
ライセンスを受けた: CC-BY-SA with attribution
所属していない Stack Overflow
このKBは合法ですか? はい、理由を学ぶ