EF的使用
步骤:
(1)将EF添加到项目:在Model右击添加新建项
找到ADO.NET实体数据模型,接着…
(2)实现数据库的增删改查
查询
(因为在Model中已经添加EF实体了,所以就可以在Controller中进行有关的数据库操作)
《controller》
//数据上下文对象
OrderDBEntities db = new OrderDBEntities();
public ActionResult Index() {
//使用SQO(标准查询运算符),查询
//实际返回的是IQueryable 接口的之类对象
//IQueryable<Models.Customer> query = db.Customers.Where(d => d.Address == "111");
//这样转有可能报异常 EnumerableQuery<Models.Customer> query = (EnumerableQuery<Models.Customer>)db.Customers.Where(d => d.Address == "111");
//DbQuery 支持延迟加载,就是只有使用到数据的时候,才去查询数据库托福答案
//DbQuery<Models.Customer> query = db.Customers.Where(d => d.Address == "111") as DbQuery<Models.Customer>;
//List<Models.Customer> list = query.ToList();
//也可以这样
// List<Models.Customer> list = db.Customers.Where(d => d.Address == "111")。ToList();
//用第二种方式:使用Linq语句,该语法只是给程序员用的,.net编译器会在编译程序集的时候把它转化为SQO
//IQueryable<Models.Customer> query = from d in db.Customers where d.Address == "111" select d;
//List<Models.Customer> list = (from d in db.Customers where d.Address == "111" select d)。ToList();
List<Models.Customer> list = (from d in db.Customers select d)。ToList();
//使用ViewData将数据传给View
ViewData["DataList"] = list;
return View();
}
《View》
<body>
<table border="1">
<!--要取到数据就直接@对应的变量 这样就可以了(导入命名空间也是一个道理)-->
@foreach (Customer a in ViewData["DataList"] as List<Customer>)
{
<tr>
<td>@a.Address</td>
<td>@a.CustomerName</td>
<td><a href="/home/del/@a.CustomerNo">删除</a>
<a href="/home/modify/@a.CustomerNo">修改</a>
</td>
</tr>
}
</table>
</body>

删除:
《Controller》
public ActionResult Del(string id) //这个id是通过超链接带过来的
{
try
{
//需要一个实体对象参数
//db.Customers.Remove(new Customer() {CustomerNo = id });
//1,创建要删除的对象
Customer modelDel = new Customer() { CustomerNo = id };
//2,将对象添加到EF管理容器中
db.Customers.Attach(modelDel);
//3,修改对象的包装类对象标识为删除状态
db.Customers.Remove(modelDel);
//4,更新到数据库
db.SaveChanges();
//5,更新成功,则命令流浪器重定向 到 /Home/Index 方法
return RedirectToAction("Index", "Home");
}
catch (Exception )
{
//指定对应跳转的视图Test下的Test.cshtml文件
return RedirectToAction("Test", "Test");
//return Content("删除失败" + ex.Message);
}
}
《View》
删除哪有什么视图,成功失败页面不给出了
修改
在视图里面肯定又个修改连接,点击跳转到对应的页面,并将参数传递给对应的函数
《View》
<body>
<table border="1">
<!--要取到数据就直接@对应的变量 这样就可以了(导入命名空间也是一个道理)-->
@foreach (Customer a in ViewData["DataList"] as List<Customer>)
{
<tr>
<td>@a.Address</td>
<td>@a.CustomerName</td>
<td><a href="/home/del/@a.CustomerNo">删除</a>
<a href="/home/modify/@a.CustomerNo">修改</a>
</td>
</tr>
}
</table>
</body>
//调用到控制器中的modify方法,并以表单的形式显示相应的页面
《Controller》
[HttpGet] //加上这个 只要是超链接发送过来的就调用这个
public ActionResult Modify(string id)
{
Customer art = (from d in db.Customers where d.Address == "111" select d)。FirstOrDefault();
//将数据传递给视图:用ViewBag viewData 使用view的构造函数托福答案
return View(art);
}
《View》
<body>
@using (Html.BeginForm("Modify", "Home", FormMethod.Post))
{
<table>
<tr>
<td colspan="2">修改</td>
</tr>
<tr>
<td>标题:@Html.HiddenFor(a=>a.CustomerNo)</td>
@*<td>@Html.TextBox("textName",(object)Model.CustomerNo)</td>*@
<!--使用htmlHelper的强类型方法,直接从Model中根据CustoomerNo生成文本框-->
<td>@Html.TextBoxFor(a =>a.CustomerNo)</td>
<td>@Html.TextBoxFor(a =>a.CustomerName)</td>
<td><input type="submit" value="确定修改" />@Html.ActionLink("返回","index","home")</td>
</tr>
</table>
}
</body>
当用户点击修改的时候又将数据以Post方式发送给Home控制器中的Modify函数进行处理
《Controller》
[HttpPost] //表单提交过来的就调用这个方法
public ActionResult Modify(Customer model)
{
try
{
//1,将实体对象加入EF对象容器中,并获取伪包装类对象
DbEntityEntry<Customer> entry = db.Entry<Customer>(model);
//2,将伪包装类对象的状态设置为unchanged
entry.State = System.Data.EntityState.Unchanged;
//3,设置被改变的属性
entry.Property(a => a.CustomerName)。IsModified = true;
//4,提交到数据库 完成修改
db.SaveChanges();
return RedirectToAction("Index", "Home");
}
catch (Exception)
{
return RedirectToAction("Test", "Test");
}
}
补充:MVC中页面之间的跳转是通过MapRouter
代码如下
routes.MapRoute(
name: "Default",
url: "{controller}/{action}/{id}",
defaults: new { controller = "Home", action = "Index", id = UrlParameter.Optional }
);

使用EF实现数据库的增删改查的更多相关文章

  1. Asp.net MVC4 使用EF实现数据库的增删改查

    EF的使用 步骤: (1)将EF添加到项目:在Model右击添加新建项 找到ADO.NET实体数据模型,接着... (2)实现数据库的增删改查       查询 (因为在Model中已经添加EF实体了 ...

  2. ThinkPHP实现对数据库的增删改查

    好久都没有更新博客了,之前老师布置的任务总算是现在可以说告一段落了,今天趁老师还没提出其他要求来更新一篇博客. 今天我想记录的是我之前做项目,自己所理解的ThinkPHP对数据库的增删改查. 首先要说 ...

  3. Android学习---数据库的增删改查(sqlite CRUD)

    上一篇文章介绍了sqlite数据库的创建,以及数据的访问,本文将主要介绍数据库的增删改查. 下面直接看代码: MyDBHelper.java(创建数据库,添加一列phone) package com. ...

  4. Android 系统API实现数据库的增删改查和SQLite3工具的使用

    在<Android SQL语句实现数据库的增删改查>中介绍了使用sql语句来实现数据库的增删改查操作,本文介绍Android 系统API实现数据库的增删改查和SQLite3工具的使用. 系 ...

  5. Android SQL语句实现数据库的增删改查

    本文介绍android中的数据库的增删改查 复习sql语法: * 增 insert into info (name,phone) values ('wuyudong','111') * 删 delet ...

  6. java jdbc 连接mysql数据库 实现增删改查

    好久没有写博文了,写个简单的东西热热身,分享给大家. jdbc相信大家都不陌生,只要是个搞java的,最初接触j2ee的时候都是要学习这么个东西的,谁叫程序得和数据库打交道呢!而jdbc就是和数据库打 ...

  7. 【转载】通过JDBC对MySQL数据库的增删改查

    通过JDBC进行简单的增删改查(以MySQL为例) 目录 前言:什么是JDBC 一.准备工作(一):MySQL安装配置和基础学习 二.准备工作(二):下载数据库对应的jar包并导入 三.JDBC基本操 ...

  8. 利用API方式进行数据库的增删改查

    /* 将数据库的增删改查单独放进一个包 */ package com.itheima28.sqlitedemo.dao; import java.util.ArrayList; import java ...

  9. MySQL数据库学习笔记(十二)----开源工具DbUtils的使用(数据库的增删改查)

    [声明] 欢迎转载,但请保留文章原始出处→_→ 生命壹号:http://www.cnblogs.com/smyhvae/ 文章来源:http://www.cnblogs.com/smyhvae/p/4 ...

随机推荐

  1. java学习之数组(二)

    在上一节中我们讲到了数组的概念,定义,以及在内存当中的表现形式.那么这里我们来说一下,数组的另一种定义方式. 在上一篇当中我们规定是这个样子定义数组的, class ArrDemo { public ...

  2. Unity 地形

    创建一个地形: GameObject —> Create Other —> Terrain; 地形的属性设置:(部分属性后面有另说,表示其他作者有说明过的内容) Base Terrain( ...

  3. Wine install, 卸载的方法

    EL6 (RHEL6 and SL6) Required packages for proper building of 32-bit Wine on 64-bit EL6 yum install - ...

  4. thinkphp引入类的使用

    比如发送邮件类phpmailer 1.将核心文件放入ORG目录下 2.在使用的地方,引入这个类文件 如何引入呢? import('@.ORG.phpmailer'); 这个表示引入当前项目中的ORG中 ...

  5. Linux Kernel 'dispatch_discard_io()'安全绕过漏洞

    漏洞版本: Linux Kernel 漏洞描述: Bugtraq ID:60414 CVE ID:CVE-2013-2140 Linux是一款开源的操作系统. 由于不充分的检查BLKIF_OP_DIS ...

  6. Light OJ 1027 - A Dangerous Maze(概率)

    题目大意: 你在一个迷宫里,你面前有n个门,你选择门的概率是一样的,每扇门有一个数字k, 加入这个数字是负数,那么这个门会花费你abs(k)分钟后把你带回原点, 假如这个数字是正数,他可以把你带出迷宫 ...

  7. 【模拟】NEERC15 A Adjustment Office (2015-2016 ACM-ICPC)(Codeforces GYM 100851)

    题目链接: http://codeforces.com/gym/100851 题目大意: 一个N*N的矩阵A,Ai,j=i+j,Q次操作,每次分两种,R r取出第r行还未被取的所有数,并输出和.C c ...

  8. Shader Forge 植物摆动

    前日才赞Shader Forge好用,今天就找到了BUG(1.03 版本) -- 获得顶点在物体空间坐标的方法绕来绕去,transform不支持齐次坐标, 不超过3行的shader代码要我出这么一个宏 ...

  9. BFS zoj 1649

    http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemCode=1649 //hnldyhy(303882171) 11:12:46 // z ...

  10. Java Struts文件上传和下载详解

    Struts2文件上传 Struts 2框架提供了内置支持处理文件上传使用基于HTML表单的文件上传.上传一个文件时,它通常会被存储在一个临时目录中,他们应该由Action类进行处理或移动到一个永久的 ...