EF总结--模型创建和数据的增删改查

       EF的创建方式有三种:

  • DataBaseFirst

       新建项-ADO.NET实体数据模型-从数据库生成

  • ModelFirst

       新建项-ADO.NET实体数据模型-空模型,在设计器中设计实体和它们之间的关系,之后右击选择从模型生成数据库。

  • CodeFirst

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 23
    评论
好的,下面是一个简单的示例: 1. 创建一个 ASP.NET MVC 项目 2. 在 Models 文件夹下创建一个名为 User.cs 的类,表示用户模型: ```csharp public class User { public int Id { get; set; } public string Name { get; set; } public string Password { get; set; } public string Email { get; set; } } ``` 3. 在 Controllers 文件夹下创建一个名为 UserController.cs 的控制器,用于处理用户相关的逻辑: ```csharp public class UserController : Controller { private readonly ApplicationDbContext _context; public UserController(ApplicationDbContext context) { _context = context; } // GET: User public ActionResult Index() { var users = _context.Users.ToList(); return View(users); } // GET: User/Create public ActionResult Create() { return View(); } // POST: User/Create [HttpPost] [ValidateAntiForgeryToken] public ActionResult Create(User user) { if (ModelState.IsValid) { _context.Users.Add(user); _context.SaveChanges(); return RedirectToAction("Index"); } return View(user); } // GET: User/Edit/5 public ActionResult Edit(int? id) { if (id == null) { return new HttpStatusCodeResult(HttpStatusCode.BadRequest); } var user = _context.Users.Find(id); if (user == null) { return HttpNotFound(); } return View(user); } // POST: User/Edit/5 [HttpPost] [ValidateAntiForgeryToken] public ActionResult Edit(User user) { if (ModelState.IsValid) { _context.Entry(user).State = EntityState.Modified; _context.SaveChanges(); return RedirectToAction("Index"); } return View(user); } // GET: User/Delete/5 public ActionResult Delete(int? id) { if (id == null) { return new HttpStatusCodeResult(HttpStatusCode.BadRequest); } var user = _context.Users.Find(id); if (user == null) { return HttpNotFound(); } return View(user); } // POST: User/Delete/5 [HttpPost, ActionName("Delete")] [ValidateAntiForgeryToken] public ActionResult DeleteConfirmed(int id) { var user = _context.Users.Find(id); _context.Users.Remove(user); _context.SaveChanges(); return RedirectToAction("Index"); } // GET: User/Login public ActionResult Login() { return View(); } // POST: User/Login [HttpPost] [ValidateAntiForgeryToken] public ActionResult Login(string name, string password) { var user = _context.Users.FirstOrDefault(u => u.Name == name && u.Password == password); if (user == null) { ModelState.AddModelError("", "用户名或密码错误"); return View(); } Session["UserId"] = user.Id; return RedirectToAction("Index"); } // GET: User/Logout public ActionResult Logout() { Session.Clear(); return RedirectToAction("Index"); } } ``` 4. 创建视图文件夹,分别在 Views/User 文件夹下创建 Index.cshtml、Create.cshtml、Edit.cshtml、Delete.cshtml、Login.cshtml 文件,用于展示用户列表、添加用户、编辑用户、删除用户和登录页面。 5. 在 Startup.cs 中配置数据库连接: ```csharp public void ConfigureServices(IServiceCollection services) { // ... services.AddDbContext<ApplicationDbContext>(options => options.UseSqlServer(Configuration.GetConnectionString("DefaultConnection"))); // ... } ``` 6. 在 appsettings.json 中配置数据库连接字符串: ```json { "ConnectionStrings": { "DefaultConnection": "Server=(localdb)\\mssqllocaldb;Database=MyDb;Trusted_Connection=True;MultipleActiveResultSets=true" }, // ... } ``` 7. 运行项目,即可进行增删改查和登录操作。 注意:上述示例中使用了 Entity Framework Core 进行数据访问,需要先安装 Microsoft.EntityFrameworkCore.SqlServer 和 Microsoft.EntityFrameworkCore.Tools NuGet 包。另外,为了简化示例,没有进行身份验证和授权,实际项目中需要进行身份验证和授权才能保证数据安全。
评论 23
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值