当前位置:   article > 正文

ASP.NET MVC 模式下配置SQLServer,创建EF执行增删改查操作_asp.net mvc加ef最简单的增删查改

asp.net mvc加ef最简单的增删查改

首先安装SqlSever 2008(版本可自己选择),安装教程在网上很多,不赘述。

1、安装完成之后,在开始程序菜单找到SSMS(Sql Sever Managerment Studio),双击进入,截图如下:

2、接下来我们建立一个新的数据库,用作存储MvcMovie中的数据。
3、数据库名称可以为MvcMovie(其它名字也可以,为了方便记忆,我们设置名字相同),其它设置默认即可。点击确定
4 、我们可以看到新建的MvcMovie数据库与系统数据库与数据库快照并列,创建成功。接下来新建Sql Sever身份验证用户。
5、常规页面,选择SQL Sever身份验证,登录名和密码自己设置,取消勾选强制实施密码策略,如下图所示:
6、点开用户映射页,勾选映射数据库:MvcMovie,下面数据库角色成员身份勾选db_owner,配置方法如下图所示:
7打开状态页,确保权限被选中允许,点击确定,如下图所示:
9、数据库与登陆用户我们都创建好以后,还要确认服务器身份验证是否允许SQL Sever身份验证模式,右击服务器,选中属性,如图所示:
打开安全性页面,确保服务器身份验证设置如下所示:
10、至此,我们已完成了对SQL Sever的配置,下一步,我们需要对VS2008下创建的ASP.NET MVC工程进行修改,打开Web.config,修改数据库连接字符串。

Web.config中,我们插入如下代码(其中各项需要根据自己情况修改,修改方法见下文):
[html]  view plain  copy
  1. <add name="MovieDBContext(DB上下文名字)" connectionString="Server=服务器名字;Database=表名;User Id=账号;Password=密码;" providerName="System.Data.SqlClient"/>  
如图 所示:
至此,编译工程,发布网站到IIS上,就完成了MVC4与SQL Sever的结合。我们可以通过访问发布到IIS上的网站,访问我们本机的数据库。

下面讲述数据库连接字符串的修改方法:
SQL Sever 2008的数据库连接字符串格式如下所示:
[html]  view plain  copy
  1. <span style="white-space: pre;">  </span>Server=myServerAddress;Database=myDataBase;User Id=myUsername;Password=myPassword;  
Sever项为服务器名称,服务器名称可以是本机( 在服务器名称那输入 . 或者 (local) )服务器名称也可以是远程服务器(在服务器名称那输入你要连接的 远程服务器的IP地址,例如:172.164.1.1)。
Database为数据库名,此处填写我们前面创建的数据库(MvcMovie)。
User Id和Password为前面我们创建的SQL Sever身份验证用户的用户名和密码。

到此SQLServer就已经搭建完成,下面就需要创建Model,并快速生成对Model也就是表的增删改查(Model的含义看你自己理解)。

EF的使用

步骤:

(1)将EF添加到项目:在Models右击添加新建项

    找到ADO.NET实体数据模型,接着添加....

(2)实现数据库的增删改查

DBContext:

  1. // <auto-generated>
  2. // 此代码已从模板生成。
  3. //
  4. // 手动更改此文件可能导致应用程序出现意外的行为。
  5. // 如果重新生成代码,将覆盖对此文件的手动更改。
  6. // </auto-generated>
  7. //------------------------------------------------------------------------------
  8. namespace WebApplication9.Models
  9. {
  10. using System;
  11. using System.Data.Entity;
  12. using System.Data.Entity.Infrastructure;
  13. public partial class NewUserTestEntities : DbContext
  14. {
  15. public NewUserTestEntities()
  16. : base("name=NewUserTestEntities")
  17. {
  18. }
  19. protected override void OnModelCreating(DbModelBuilder modelBuilder)
  20. {
  21. throw new UnintentionalCodeFirstException();
  22. }
  23. public virtual DbSet<Users> Users { get; set; }//对表的操作需要用到Users对象
  24. }
  25. }
UsersModel:
  1. //------------------------------------------------------------------------------
  2. // <auto-generated>
  3. // 此代码已从模板生成。
  4. //
  5. // 手动更改此文件可能导致应用程序出现意外的行为。
  6. // 如果重新生成代码,将覆盖对此文件的手动更改。
  7. // </auto-generated>
  8. //------------------------------------------------------------------------------
  9. namespace WebApplication9.Models
  10. {
  11. using System;
  12. using System.Collections.Generic;
  13. public partial class Users
  14. {
  15. public string UserName { get; set; }
  16. public string Password { get; set; }
  17. public Nullable<int> age { get; set; }
  18. }
  19. }

UsersController.cs

  1. using System;
  2. using System.Collections.Generic;
  3. using System.Data;
  4. using System.Data.Entity;
  5. using System.Linq;
  6. using System.Net;
  7. using System.Web;
  8. using System.Web.Mvc;
  9. using WebApplication9.Models;
  10. namespace WebApplication9.Controllers
  11. {
  12. public class UsersController : Controller
  13. {
  14. private NewUserTestEntities db = new NewUserTestEntities();
  15. // GET: /Users/
  16. public ActionResult Index()
  17. {
  18. return View(db.Users.ToList());
  19. }
  20. // GET: /Users/Details/5
  21. public ActionResult Details(string id)
  22. {
  23. if (id == null)
  24. {
  25. return new HttpStatusCodeResult(HttpStatusCode.BadRequest);
  26. }
  27. Users users = db.Users.Find(id);
  28. if (users == null)
  29. {
  30. return HttpNotFound();
  31. }
  32. return View(users);
  33. }
  34. // GET: /Users/Create
  35. public ActionResult Create()
  36. {
  37. return View();
  38. }
  39. // POST: /Users/Create
  40. // 为了防止“过多发布”攻击,请启用要绑定到的特定属性,有关
  41. // 详细信息,请参阅 http://go.microsoft.com/fwlink/?LinkId=317598。
  42. [HttpPost]
  43. [ValidateAntiForgeryToken]
  44. public ActionResult Create([Bind(Include="UserName,Password,age")] Users users)
  45. {
  46. if (ModelState.IsValid)
  47. {
  48. db.Users.Add(users);
  49. db.SaveChanges();
  50. return RedirectToAction("Index");
  51. }
  52. return View(users);
  53. }
  54. // GET: /Users/Edit/5
  55. public ActionResult Edit(string id)
  56. {
  57. if (id == null)
  58. {
  59. return new HttpStatusCodeResult(HttpStatusCode.BadRequest);
  60. }
  61. Users users = db.Users.Find(id);
  62. if (users == null)
  63. {
  64. return HttpNotFound();
  65. }
  66. return View(users);
  67. }
  68. // POST: /Users/Edit/5
  69. // 为了防止“过多发布”攻击,请启用要绑定到的特定属性,有关
  70. // 详细信息,请参阅 http://go.microsoft.com/fwlink/?LinkId=317598。
  71. [HttpPost]
  72. [ValidateAntiForgeryToken]
  73. public ActionResult Edit([Bind(Include="UserName,Password,age")] Users users)
  74. {
  75. if (ModelState.IsValid)
  76. {
  77. db.Entry(users).State = EntityState.Modified;
  78. db.SaveChanges();
  79. return RedirectToAction("Index");
  80. }
  81. return View(users);
  82. }
  83. // GET: /Users/Delete/5
  84. public ActionResult Delete(string id)
  85. {
  86. if (id == null)
  87. {
  88. return new HttpStatusCodeResult(HttpStatusCode.BadRequest);
  89. }
  90. Users users = db.Users.Find(id);
  91. if (users == null)
  92. {
  93. return HttpNotFound();
  94. }
  95. return View(users);
  96. }
  97. // POST: /Users/Delete/5
  98. [HttpPost, ActionName("Delete")]
  99. [ValidateAntiForgeryToken]
  100. public ActionResult DeleteConfirmed(string id)
  101. {
  102. Users users = db.Users.Find(id);
  103. db.Users.Remove(users);
  104. db.SaveChanges();
  105. return RedirectToAction("Index");
  106. }
  107. protected override void Dispose(bool disposing)
  108. {
  109. if (disposing)
  110. {
  111. db.Dispose();
  112. }
  113. base.Dispose(disposing);
  114. }
  115. }
  116. }

View:Index.cshtml

  1. @model IEnumerable<WebApplication9.Models.Users>
  2. @{
  3. ViewBag.Title = "Index";
  4. }
  5. <h2>Index</h2>
  6. <p>
  7. @Html.ActionLink("Create New", "Create")
  8. </p>
  9. <table class="table">
  10. <tr>
  11. <th>
  12. @Html.DisplayNameFor(model => model.UserName)
  13. </th>
  14. <th>
  15. @Html.DisplayNameFor(model => model.Password)
  16. </th>
  17. <th>
  18. @Html.DisplayNameFor(model => model.age)
  19. </th>
  20. <th></th>
  21. </tr>
  22. @foreach (var item in Model) {
  23. <tr>
  24. <td>
  25. @Html.DisplayFor(modelItem => item.UserName)
  26. </td>
  27. <td>
  28. @Html.DisplayFor(modelItem => item.Password)
  29. </td>
  30. <td>
  31. @Html.DisplayFor(modelItem => item.age)
  32. </td>
  33. <td>
  34. @Html.ActionLink("Edit", "Edit", new { id=item.UserName }) |
  35. @Html.ActionLink("Details", "Details", new { id=item.UserName }) |
  36. @Html.ActionLink("Delete", "Delete", new { id=item.UserName })
  37. </td>
  38. </tr>
  39. }
  40. </table>



声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/很楠不爱3/article/detail/341866
推荐阅读
相关标签
  

闽ICP备14008679号