我的索引无法访问

时间:2013-05-01 18:37:04

标签: c# asp.net sql-server asp.net-mvc

我正在使用C#和SQL Server 2005开发ASP .Net MVC 3应用程序。

我已经使用他们的控制器(User& Poste)创建了2个模型(UserController& PosteController),这要归功于使用'Read /创建的方法使用Entity Framework'编写动作和视图。

Poste的一切顺利,我可以创建,编辑,删除......

问题与User有关。事实上,当我在我的网址中添加/User来访问索引时,我会看到此错误:

  

描述:执行期间发生了未处理的异常   当前的网络请求。请查看堆栈跟踪了解更多信息   有关错误的信息以及它在代码中的起源。

     

异常详细信息:System.Data.SqlClient.SqlException:Nom d'objet   'dbo.Users'非valide。

这是User型号代码:

    public class User
    {
        [Required]
        [Key]
        [Display(Name = "Matricule :")]
        public string Matricule { get; set; }

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

        [Required]
        [StringLength(100, ErrorMessage = "Le {0} doit avoir au minimum {2} caractères.", MinimumLength = 6)]
        [DataType(DataType.Password)]
        [Display(Name = "Mot de passe :")]
        public string passWord { get; set; }

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

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

    public class GammeDBContext : DbContext
    {
        public DbSet<User> Users { get; set; }
    }

这是UserController代码:

    public class UserController : Controller
    {
        private GammeDBContext db = new GammeDBContext();

        //
        // GET: /User/
        public ViewResult Index()
        {
            return View(db.Users.ToList());
        }

        //
        // GET: /User/Details/5
        public ViewResult Details(string id)
        {
            User user = db.Users.Find(id);
            return View(user);
        }

        //
        // GET: /User/Create
        public ActionResult Create()
        {
            return View();
        } 

        //
        // POST: /User/Create
        [HttpPost]
        public ActionResult Create(User user)
        {
            if (ModelState.IsValid)
            {
                db.Users.Add(user);
                db.SaveChanges();
                return RedirectToAction("Index");  
            }

            return View(user);
        }

        //
        // GET: /User/Edit/5
        public ActionResult Edit(string id)
        {
            User user = db.Users.Find(id);
            return View(user);
        }

        //
        // POST: /User/Edit/5
        [HttpPost]
        public ActionResult Edit(User user)
        {
            if (ModelState.IsValid)
            {
                db.Entry(user).State = EntityState.Modified;
                db.SaveChanges();
                return RedirectToAction("Index");
            }
            return View(user);
        }

        //
        // GET: /User/Delete/5
        public ActionResult Delete(string id)
        {
            User user = db.Users.Find(id);
            return View(user);
        }

        //
        // POST: /User/Delete/5
        [HttpPost, ActionName("Delete")]
        public ActionResult DeleteConfirmed(string id)
        {            
            User user = db.Users.Find(id);
            db.Users.Remove(user);
            db.SaveChanges();
            return RedirectToAction("Index");
        }

        protected override void Dispose(bool disposing)
        {
            db.Dispose();
            base.Dispose(disposing);
        }
    }

这就是我在web.config文件中添加的内容:

<add name="GammeDBContext" 
     connectionString="Data Source=SWEET-DE396641E\SQLEXPRESS;database=Flux; Integrated Security=true" 
     providerName="System.Data.SqlClient" />
<add name="GammeDBContextP" 
     connectionString="Data Source=SWEET-DE396641E\SQLEXPRESS;database=Flux; Integrated Security=true" 
     providerName="System.Data.SqlClient" />

PS:

  • GammeDBContext适用于“用户”
  • GammeDBContextP代表“Poste”

那有什么解决方案吗?

1 个答案:

答案 0 :(得分:0)

是您的数据库表名为'User'?如果是,请尝试将此代码放入上下文类中。

protected override void OnModelCreating(DbModelBuilder modelBuilder)
    {
        modelBuilder.Conventions.Remove<System.Data.Entity.ModelConfiguration.Conventions.PluralizingTableNameConvention>();
    }

这一次让我失去了bajeezus。

为什么你有2个相同的连接字符串?