概述
首先安装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中,我们插入如下代码(其中各项需要根据自己情况修改,修改方法见下文):
- <add name="MovieDBContext(DB上下文名字)" connectionString="Server=服务器名字;Database=表名;User Id=账号;Password=密码;" providerName="System.Data.SqlClient"/>
至此,编译工程,发布网站到IIS上,就完成了MVC4与SQL Sever的结合。我们可以通过访问发布到IIS上的网站,访问我们本机的数据库。
下面讲述数据库连接字符串的修改方法:
SQL Sever 2008的数据库连接字符串格式如下所示:
- <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:
// <auto-generated>
// 此代码已从模板生成。
//
// 手动更改此文件可能导致应用程序出现意外的行为。
// 如果重新生成代码,将覆盖对此文件的手动更改。
// </auto-generated>
//------------------------------------------------------------------------------
namespace WebApplication9.Models
{
using System;
using System.Data.Entity;
using System.Data.Entity.Infrastructure;
public partial class NewUserTestEntities : DbContext
{
public NewUserTestEntities()
: base("name=NewUserTestEntities")
{
}
protected override void OnModelCreating(DbModelBuilder modelBuilder)
{
throw new UnintentionalCodeFirstException();
}
public virtual DbSet<Users> Users { get; set; }//对表的操作需要用到Users对象
}
}
UsersModel:
//------------------------------------------------------------------------------
// <auto-generated>
// 此代码已从模板生成。
//
// 手动更改此文件可能导致应用程序出现意外的行为。
// 如果重新生成代码,将覆盖对此文件的手动更改。
// </auto-generated>
//------------------------------------------------------------------------------
namespace WebApplication9.Models
{
using System;
using System.Collections.Generic;
public partial class Users
{
public string UserName { get; set; }
public string Password { get; set; }
public Nullable<int> age { get; set; }
}
}
UsersController.cs
using System;
using System.Collections.Generic;
using System.Data;
using System.Data.Entity;
using System.Linq;
using System.Net;
using System.Web;
using System.Web.Mvc;
using WebApplication9.Models;
namespace WebApplication9.Controllers
{
public class UsersController : Controller
{
private NewUserTestEntities db = new NewUserTestEntities();
// GET: /Users/
public ActionResult Index()
{
return View(db.Users.ToList());
}
// GET: /Users/Details/5
public ActionResult Details(string id)
{
if (id == null)
{
return new HttpStatusCodeResult(HttpStatusCode.BadRequest);
}
Users users = db.Users.Find(id);
if (users == null)
{
return HttpNotFound();
}
return View(users);
}
// GET: /Users/Create
public ActionResult Create()
{
return View();
}
// POST: /Users/Create
// 为了防止“过多发布”攻击,请启用要绑定到的特定属性,有关
// 详细信息,请参阅 http://go.microsoft.com/fwlink/?LinkId=317598。
[HttpPost]
[ValidateAntiForgeryToken]
public ActionResult Create([Bind(Include="UserName,Password,age")] Users users)
{
if (ModelState.IsValid)
{
db.Users.Add(users);
db.SaveChanges();
return RedirectToAction("Index");
}
return View(users);
}
// GET: /Users/Edit/5
public ActionResult Edit(string id)
{
if (id == null)
{
return new HttpStatusCodeResult(HttpStatusCode.BadRequest);
}
Users users = db.Users.Find(id);
if (users == null)
{
return HttpNotFound();
}
return View(users);
}
// POST: /Users/Edit/5
// 为了防止“过多发布”攻击,请启用要绑定到的特定属性,有关
// 详细信息,请参阅 http://go.microsoft.com/fwlink/?LinkId=317598。
[HttpPost]
[ValidateAntiForgeryToken]
public ActionResult Edit([Bind(Include="UserName,Password,age")] Users users)
{
if (ModelState.IsValid)
{
db.Entry(users).State = EntityState.Modified;
db.SaveChanges();
return RedirectToAction("Index");
}
return View(users);
}
// GET: /Users/Delete/5
public ActionResult Delete(string id)
{
if (id == null)
{
return new HttpStatusCodeResult(HttpStatusCode.BadRequest);
}
Users users = db.Users.Find(id);
if (users == null)
{
return HttpNotFound();
}
return View(users);
}
// POST: /Users/Delete/5
[HttpPost, ActionName("Delete")]
[ValidateAntiForgeryToken]
public ActionResult DeleteConfirmed(string id)
{
Users users = db.Users.Find(id);
db.Users.Remove(users);
db.SaveChanges();
return RedirectToAction("Index");
}
protected override void Dispose(bool disposing)
{
if (disposing)
{
db.Dispose();
}
base.Dispose(disposing);
}
}
}
View:Index.cshtml
@model IEnumerable<WebApplication9.Models.Users>
@{
ViewBag.Title = "Index";
}
<h2>Index</h2>
<p>
@Html.ActionLink("Create New", "Create")
</p>
<table class="table">
<tr>
<th>
@Html.DisplayNameFor(model => model.UserName)
</th>
<th>
@Html.DisplayNameFor(model => model.Password)
</th>
<th>
@Html.DisplayNameFor(model => model.age)
</th>
<th></th>
</tr>
@foreach (var item in Model) {
<tr>
<td>
@Html.DisplayFor(modelItem => item.UserName)
</td>
<td>
@Html.DisplayFor(modelItem => item.Password)
</td>
<td>
@Html.DisplayFor(modelItem => item.age)
</td>
<td>
@Html.ActionLink("Edit", "Edit", new { id=item.UserName }) |
@Html.ActionLink("Details", "Details", new { id=item.UserName }) |
@Html.ActionLink("Delete", "Delete", new { id=item.UserName })
</td>
</tr>
}
</table>
最后
以上就是爱笑小丸子为你收集整理的ASP.NET MVC 模式下配置SQLServer,创建EF执行增删改查操作的全部内容,希望文章能够帮你解决ASP.NET MVC 模式下配置SQLServer,创建EF执行增删改查操作所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复