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 }
 );

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

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

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

  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中获取完整的url

    Java中获得完整的URl字符串 HttpServletRequest httpRequest=(HttpServletRequest)request; String strBackUrl = &qu ...

  2. cdev、udev

    udev :应用层的守护进程,由启动脚本加载,负责建立热拨插的接点 cdev :建立字符设备接口 platform device :相关平台直接总线建立的设备,主要出现需要自己直接挂到平台的时候,因为 ...

  3. jpa+spring配置多数据源

    property name="hibernate.connection.url" value="jdbc:mysql://localhost:3306/test?useU ...

  4. 无锁编程(六) - seqlock(顺序锁)

    seqlock(顺序锁) 用于能够区分读与写的场合,并且是读操作很多.写操作很少,写操作的优先权大于读操作. seqlock的实现思路是,用一个递增的整型数表示sequence.写操作进入临界区时,s ...

  5. 基于Linux的oracle数据库管理 part3( 存储 网络 常用命令 )

    主要内容 1. 常用存储模式 2. 配置网络 3. 维护指令 常用存储模式 - 文件系统 优点:管理方便, 缺点:读写慢 - 裸设备 只没有被格式化和挂载的磁盘, 只能有程序直接访问, 不能被操作系统 ...

  6. find-right-interval

    https://leetcode.com/problems/find-right-interval/ Java里面TreeMap或者TreeSet有类似C++的lower_bound或者upper_b ...

  7. 创建xml时,设置xml编码问题

    OutputFormat format = OutputFormat.createPrettyPrint();    format.setEncoding("GBK"); XMLW ...

  8. Qt之密码框不可选中、复制、粘贴、无右键菜单等

    简述 在做用户登录.修改密码的时候,往往会用到密码框,其中一些功能要求与普通的输入框不同,例如:不能选中.复制.粘贴.无右键菜单等功能,当然设置密码不可见是必须的! 下面介绍两种方式来实现相同的效果. ...

  9. 用Visio画UML用例图

    1.用例图 用例图描述参与者所理解的系统功能.主要元素是用例和参与者. 用例图的4个基本组件:参与者(Actor).用例(Use Case).关系(Relationship)和系统. 下面以银行储蓄系 ...

  10. LA 3971 (二分) Assemble

    题意: 你有b块钱想要组装一台电脑.给出n个配件的种类,品质和价格,要求每个种类的配件各买一个总价格不超过b且“品质最差配件”的品质因子应尽量大. 这种情况下STL的map的确很好用,学习学习 这种最 ...