我是靠谱客的博主 爱笑小丸子,最近开发中收集的这篇文章主要介绍ASP.NET MVC 模式下配置SQLServer,创建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:

// <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执行增删改查操作所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(64)

评论列表共有 0 条评论

立即
投稿
返回
顶部