繁体   English   中英

ASP.NET MVC4设置DB上下文和模型

[英]ASP.NET MVC4 Setting up DB Context and Models

我正在使用ASP.NET MVC4项目(学校项目,所以我正在学习框架),尝试使用Code-first透视图获得工作实体框架6.0。 我创建了我的模型( /Models/ )和DbContext如下所示:

using System;
using System.Data.Entity;
using System.Data.Entity.ModelConfiguration.Conventions;

namespace Autokereskedes.Models
{
    public class AutoDb : DbContext
    {
        public DbSet<Car> Cars { get; set; }
        public DbSet<Reservation> Reservations { get; set; }
        public DbSet<Depo> Depos { get; set; }
        public DbSet<User> Users { get; set; }

        protected override void OnModelCreating(DbModelBuilder modelBuilder)
        {
            modelBuilder.Conventions.Remove<OneToManyCascadeDeleteConvention>();

            base.OnModelCreating(modelBuilder);
        }
    }
}

但是当我想在我的控制器中使用它时,我得到一个错误

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.Mvc;
using Autokereskedes.Models;

namespace Autokereskedes.Controllers
{
    public class AccountController : Controller
    {

......

private bool IsUserDataValid(string email, string password)
{
    bool r = false;
    var crypto = new SimpleCrypto.PBKDF2();
    using (var d = new AutoDb())
    {
        var user = new d.SystemUsers.FirstOrDefault( u => u.email == email);
        if (user != null && user.Password == crypto.Compute(password))
        {
            r = true;
        }
    }

    return r;
}

错误是:

Error   1   The type or namespace name 'd' could not be found (are you missing a using directive or an assembly reference?) C:\_temp\stackoverflow\Autokereskedes\Controllers\AccountController.cs  64  32  Autokereskedes

另外,我无法真正使用这些模型,我认为当我编写表关系时我犯了错误(我的表主要有一对多关联),当我使用模型时,我得到了外键错误(HomeController)。

我的整个项目可以访问: 下载

感谢您的时间和帮助,我在这里迷失了,浏览教程但仍然忽略了重点。

我想它应该是

var user = new d.Users.FirstOrDefault( u => u.email == email);

可以试试这个

 var user = d.Users.ToList().FirstOrDefault(u => u.Email == email);

.NET认为你试图在命名空间d.SystemUsers中实例化一个名为FirstOrDefault的类,而你只是试图引用你刚刚创建的d对象的SystemUsers属性。

所以尝试删除“新”:

using (var d = new AutoDb())
{
    var user = d.SystemUsers.FirstOrDefault( u => u.email == email);
    if (user != null && user.Password == crypto.Compute(password))
    {
        r = true;
    }
}

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM