3

私はこの問題を解決しようとしていますが、私が進んでいくにつれて多くのことを学んでいるので、誰かが私がどこで間違っているのか、および/または私が読むことができるいくつかの良いリソースを説明してくれると本当に感謝しています.上。

したがって、データベースの Entity Framework モデルに基づくモデルと、そのモデルのプロパティを表すビューモデルがあります。データ (js ファイルで定義) を表示する剣道グリッドを構築し、コントローラーのメソッドが Json 結果セットを返します。問題は、結合された db テーブルに値を表示しようとすると、キー値が設定されていない場合、nullreferenceexception エラーが発生することです。明らかに、これが起こらないようにコーディングする方法が必要なので、ここでパズルの一部が欠けています。どんな助けでもありがたく受け取られます!

私のモデルは次のようなものです:

namespace TrainingKendoUI.Models
{
    using System;
    using System.Collections.Generic;

    public partial class TRAINING_EMPLOYEE_COURSES
    {
        public int EMP_COURSE_ID { get; set; }
        public int EMPLOYEE_ID { get; set; }
        public int COURSE_ID { get; set; }
        public Nullable<System.DateTime> DATE_ATTENDED { get; set; }
        public Nullable<decimal> COURSE_COST { get; set; }
        public string COURSE_RESITS { get; set; }
        public Nullable<int> PROVIDER_ID { get; set; }
        public Nullable<int> EMP_COURSE_STATUS_ID { get; set; }
        public Nullable<int> VENUE_ID { get; set; }

        public virtual TRAINING_COURSES TRAINING_COURSES { get; set; }
        public virtual TRAINING_EMPLOYEE_COURSE_STATUS TRAINING_EMPLOYEE_COURSE_STATUS  { get; set; }
        public virtual TRAINING_EMPLOYEES TRAINING_EMPLOYEES { get; set; }
        public virtual TRAINING_PROVIDERS TRAINING_PROVIDERS { get; set; }
        public virtual TRAINING_VENUES TRAINING_VENUES { get; set; }
    }
}

私のコントローラーメソッドは次のようになります。

    public JsonResult EmployeeCourses_Read()
    {
        var model = db.TRAINING_EMPLOYEE_COURSES;
        var ViewModel = new List<EmployeeCoursesIntersectionViewModel>();

        foreach (var employee in model)
        {
            ViewModel.Add(new EmployeeCoursesIntersectionViewModel(employee));
        }

        return Json(ViewModel, JsonRequestBehavior.AllowGet);
    }

そして私のビューモデルはこれが好きです:

namespace TrainingKendoUI.ViewModels
{
    public class EmployeeCoursesIntersectionViewModel
    {

        #region Constructors

            public EmployeeCoursesIntersectionViewModel()
            {

            }

            public EmployeeCoursesIntersectionViewModel(TRAINING_EMPLOYEE_COURSES  model)
            {
                this.empCourseId = model.EMP_COURSE_ID;
                this.employee = model.TRAINING_EMPLOYEES.FIRST_NAME;
                this.course = model.TRAINING_COURSES.COURSE_NAME;
                this.dateAttended = model.DATE_ATTENDED;
                this.cost = model.COURSE_COST;
                this.resits = model.COURSE_RESITS;
                //These lines will produce a NullReference error if not set through the front end...
                this.provider = model.TRAINING_PROVIDERS.PROVIDER_NAME;
                this.status =    model.TRAINING_EMPLOYEE_COURSE_STATUS.EMP_COURSE_STATUS;
                this.venue = model.TRAINING_VENUES.VENUE_NAME;

        }

        #endregion

        #region Properties

        public int empCourseId { get; set; }
        public string employee { get; set; }
        public string course { get; set; }
        public Nullable<System.DateTime> dateAttended { get; set; }
        public Nullable<decimal> cost { get; set; }
        public string resits { get; set; }
        public string provider { get; set; }
        public string status { get; set; }
        public string venue { get; set; }

        #endregion

    }
}
4

1 に答える 1

1

オブジェクトを設定する前に null チェックを行います。

this.provider = model.TRAINING_PROVIDERS == null ? "" 
                        : model.TRAINING_PROVIDERS.PROVIDER_NAME;

ステータスと会場についても同様に行う必要があります

this.status =    model.TRAINING_EMPLOYEE_COURSE_STATUS== null ? ""
                        model.TRAINING_EMPLOYEE_COURSE_STATUS.EMP_COURSE_STATUS;
this.venue = model.TRAINING_VENUES== null ? ""
                        model.TRAINING_VENUES.VENUE_NAME;
于 2014-02-21T14:31:42.403 に答える