1

データベース層に ASP.NET MVC 4 コードの最初のパターンを使用しています。UserProfile と Task の間に多対多の関係があります。ユーザーのタスクのコレクションにタスクを追加しようとすると、追加されますが、クエリを実行してそこにあるかどうかを確認しようとすると、表示されません。

私のモデル:

public class UserProfile
{
    [Key]
    [DatabaseGeneratedAttribute(DatabaseGeneratedOption.Identity)]
    public int UserId { get; set; }
    public string UserName { get; set; }
    public string FirstName { get; set; }
    public string SirName { get; set; }
    public string Position { get; set; }
    public string Email { get; set; }
    public ICollection<TaskModels> Tasks {get; set; }
    public bool? isActive { get; set; }

    public UserProfile()
    {
        Tasks = new HashSet<TaskModels>();
    }
}

public class TaskModels
{
    public int Id { get; set; }
    public string Name { get; set; }
    public string Description { get; set; }
    public DateTime? StartDate { get; set; }
    public DateTime? EndDate { get; set; }
    public ICollection<UserProfile> Employees { get; set; }
    public int TimeNeeded { get; set; }
    public int TimeWorked { get; set; }
    public string Status { get; set; }
    public bool isActive { get; set; }

    public TaskModels()
    {
        Employees = new HashSet<UserProfile>();
    }
}

public class WorkLogModels
{
    public int Id { get; set; }
    public UserProfile Author { get; set; }
    public DateTime TimeBeganWorking { get; set; }
    public int TimeWorkedOn { get; set; }
    public TaskModels Task { get; set; }
    public string Description { get; set; }
}

public class TimeTrackerDb : DbContext { public TimeTrackerDb() : base("DefaultConnection") {

    }

    public DbSet<UserProfile> UserProfiles { get; set; }
    public DbSet<TaskModels> Tasks { get; set; }
    public DbSet<WorkLogModels> WorkLogs { get; set; }
}

タスクの Employees リストに UserProfile が既に存在するかどうかを確認しようとしましたが、常に空です。

    [HttpPost]
    public ActionResult Create(WorkLogModels worklogmodels)
    {
        var tasks = db.Tasks.Where(x => x.Name == worklogmodels.Task.Name).SingleOrDefault();
        if (tasks == null)
        {
            return View(worklogmodels);
        }
        if (ModelState.IsValid)
        {
            var user = db.UserProfiles.Where(x => x.UserId == WebSecurity.CurrentUserId).FirstOrDefault();
            var task = db.Tasks.Where(x => x.Name == worklogmodels.Task.Name).FirstOrDefault();
            WorkLogModels log = new WorkLogModels();
            log.Description = worklogmodels.Description;
            log.TimeBeganWorking = worklogmodels.TimeBeganWorking;
            log.TimeWorkedOn = worklogmodels.TimeWorkedOn;
            log.Author = user;
            log.Task = task;
            db.WorkLogs.Add(log);

            if (!db.UserProfiles.Where(x => x.UserId == WebSecurity.CurrentUserId).First().Tasks.Any(x=> x.Name == worklogmodels.Task.Name))
            {
                db.UserProfiles.Where(x => x.UserId == WebSecurity.CurrentUserId).FirstOrDefault().Tasks.Add(task);
                db.Tasks.Where(x => x.Name == worklogmodels.Task.Name).FirstOrDefault().Employees.Add(user);
            }
            db.SaveChanges();
            return RedirectToAction("Index");
        }

        return View(worklogmodels);
    }

私はこれで2日間戦っています。

どんな助けでも大歓迎です

編集:

私が自分自身を明らかにしたかどうかはわかりません。WorkLog コントローラーの Crate アクションで、現在のユーザーを現在のタスクのコレクションに入れようとしています。最初は正しく動作しますが、もう一度実行すると、if ステートメントをスキップできず、もう一度追加しようとして例外がスローされます: System.Data.SqlClient.SqlException. 同じレコードを中間テーブルに追加しようとしています。

4

0 に答える 0