[英]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.