0

C# と SQL Server 2005 を使用して ASP .Net MVC 3 アプリケーションを開発しています。

「Entity Frameworkを使用した読み取り/書き込みアクションとビュー」を使用した作成方法のおかげで、コントローラー(UserControllerとPosteController)を使用して2つのモデル(UserとPoste)を作成しました。

User または Poste のビューにアクセスしたい場合、つまり /Poste (または /User) を URL に入れてインデックスにアクセスすると、次のエラーが表示されます。

オブジェクト名 'dbo.Poste' が無効です。またはオブジェクト名 'dbo.User' が無効です。

これは User のモデルです:

using System;
using System.Collections.Generic;
using System.ComponentModel.DataAnnotations;
using System.Globalization;
using System.Web.Mvc;
using System.Web.Security;
using System.Data.SqlClient;
using System.Data.Entity;
namespace MvcApplication2.Models
{
    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; }
    }
}

これは User の Controller です:

using System;
using System.Collections.Generic;
using System.Data;
using System.Data.Entity;
using System.Linq;
using System.Web;
using System.Web.Mvc;
using MvcApplication2.Models;

namespace MvcApplication2.Controllers
{ 
    public class UserController : Controller
    {
        private GammeContext db = new GammeContext();

        //
        // 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);
        }
    }
}

これはコンテキスト クラス (GammeContext) です。

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Data.Entity;

namespace MvcApplication2.Models
{
    public class GammeContext:DbContext
    {

        public DbSet<Poste> Postes { get; set; }

         public DbSet<User> Users { get; set; }


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

これは、web.config ファイルに追加したものです。

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

1 に答える 1

0

新しいクエリ エディタ ウィンドウに次のクエリを記述して、User テーブルが存在するかどうかをデータベースに確認します。

select * from dbo.User

これを実行できるかもしれません:

select * from User

これは、このテーブル スキーマが「dbo」オブジェクトではなくデフォルト ユーザーに関連付けられているためです。

これを修正するには、次のクエリを実行して User を dbo.User にコピーする必要があります。

select * into dbo.User from User
于 2013-05-02T08:37:42.227 に答える