asp.net mvc5 step by step(一)——CURD增删查改Demo

1、  新建一个项目:

2、  在Models文件夹新增类。

代码如下:

public class Product
 {
        [Key]
        public int Id { get; set; }
        public string ProductName { get; set; }
        public decimal Price { get; set; }
        public string  Descript { get; set; }
}

注意,这里的特性:[Key]是指定Id为主键。这里要引用

using System.ComponentModel.DataAnnotions

命名空间。

3、  向项目新建文件夹:Context用于存放DbContext,

1、  在DbContext文件夹下新建类:

ProductContext

代码为:

 public class ProductContext:DbContext
 {
        public DbSet<Product> Products { get; set; }
}

注意,这个类继承自DbContext,DbContext在System.Data.Entity中定义,所以要引用此命名空间。还要引用: WebApplication3.Models;

5、添加控制器(Controller).

6、在控制器类ProductController加入

ProductContext db = new ProductContext();  //使用Context

7、修改Index Action

改为:

        public ActionResult Index()
        {
            return View(db.Products.ToList());
        }

8、重新生成项目,因为不生成项目,下一步添加View会出错。

9、在Index Action内按右键,添加View

至此完成 查询的代码,可以运行查看一下校果。

这时点击Create New 按钮,会报错,因为还没有实现Create New 的View.

10、接下来,来实现Create New 功能。

11、添加Create View ,在Create Action里右击。

 回到ProductController

修改Create的PostAction,代码改为:(注意这里要引用WebApplication3.Models;)

        // POST: Product/Create   注意,这里修改的是有[HttpPost]特性的Create Action
        [HttpPost]
        public ActionResult Create(Product product)
        {
            try
            {

                if (ModelState.IsValid)  //验证数据有效性
                {
                    db.Products.Add(product);
                    db.SaveChanges();
                    return RedirectToAction("Index");
                }
                //验证不通过
                return View(product);//返回Model给View

            }
            catch
            {
                return View();
            }
        }

运行,测试。能新增记录,说明测试OK

12、下面完成Details View。按上面方法新建View

修改:Details Action的代码:(注意这里要引用:System.Net,   HttpStatusCode在System.Net中定义。)

        public ActionResult Details(int? id)
        {
            if (id == null)
            {
                return new HttpStatusCodeResult(HttpStatusCode.BadRequest);
            }
            Product product = db.Products.Find(id);
            if (product == null)
            {
                return new HttpNotFoundResult();
            }

            return View(product);
        }

OK,详情页面完成。

13、现在做Edit,按照上面方法建立View.

修改Create Action ,注意修改Get那个。代码为:

        // GET: Product/Edit/5
        public ActionResult Edit(int? id)
        {
            if (id == null)
            {
                return new HttpStatusCodeResult(HttpStatusCode.BadRequest);
            }
            Product product = db.Products.Find(id);
            if (product == null)
            {
                return new HttpNotFoundResult();
            }

            return View(product);
        }

修改Create Action 有[HttpPost]特性那个,代码为:

        [HttpPost]
        public ActionResult Edit( Product product)
        {
            try
            {
                if (ModelState.IsValid)
                {
                    db.Entry(product).State = System.Data.Entity.EntityState.Modified;
                    db.SaveChanges();
                    return RedirectToAction("Index");
                }
                return View(product);
            }
            catch
            {
                return View();
            }
        }

修改完成!

14,最后做删除。新建Delete Action

修改Controller代码:

        // GET: Product/Delete/5
        public ActionResult Delete(int? id)
        {
            if (id == null)
            {
                return new HttpStatusCodeResult(HttpStatusCode.BadRequest);
            }
            Product product = db.Products.Find(id);
            if (product == null)
            {
                return new HttpNotFoundResult();
            }

            return View(product);
        }

        // POST: Product/Delete/5
        [HttpPost]
        public ActionResult Delete(int? id,Product pro)
        {
            try
            {
                Product p = new Product();
                if (ModelState.IsValid)
                {
                    if (id == null)
                    {
                        return  new HttpStatusCodeResult(HttpStatusCode.BadRequest);
                    }
                    p = db.Products.Find(id);
                    if (p == null)
                    {
                        return new HttpNotFoundResult();
                    }
                    db.Products.Remove(p);
                    db.SaveChanges();
                    return RedirectToAction("Index");
                }

                return View(p);
            }
            catch
            {
                return View();
            }
        }

OK,运行一下,一切正常。

下一节,说说Data Annotations

时间: 2024-10-06 11:34:18

asp.net mvc5 step by step(一)——CURD增删查改Demo的相关文章

asp.net MVC最简单的增删查改!(详)

折腾了两天搞出来,但原理性的东西还不是很懂,废话不多说上图上代码 然后右键models,新建一个数据模型 注意我添加命名为lianxi 添加后如上 接下来在controllers添加控制器还有在Views中添加视图 注意控制器lianxi和视图的名字要一致,然后视图我是添加了3个分别是Index,insert,Modify,在控制器里分别有三个对应的函数 每当用URL访问视图时,他就调用了controllers对应的方法,例如 jiaEntities 就是建立模式时那个数据链接的名字      

Asp.Net+Oracle+EasyUI简单增删查改

Asp.Net+Oracle+EasyUI简单增删查改 概要:网上有很多关于EasyUI前端框架的资料,本人在学习的基础上,基于自己之前搭建的框架(Oracle+Ado.Net),配合EasyUI实现一套简单的增删查改. 正文: 在实体层新建一个EMP.cs,继承至BaseModel 1 namespace myOracle.Model 2 { 3 public class Emp:BaseModel 4 { 5 public Emp() 6 { 7 base.PrimaryKey = "emp

Asp.Net Mvc+MongoDB简单增删查改

                                   Asp.Net Mvc+MongoDB简单增删查改 概要:现在很多企业都在使用非关系型的NoSql数据库,其中MongoDB是相当热门的,最近有空就研究了一下,本文写了一套基于Asp.Net Mvc和MongoDB的简单增删查改,本文部分内容是借用其他博文,最后我会贴出出处. 正文: 在控制器的Models中新建一个UserModel模型(其中相当于另开一个类库,类似Dal层) using System; using Syst

EF6与mvc5系列(2):实现基本的增删查改

在上节中添加控制器以后,项目中自动生成了增删改查视图.本节中我们将对其进行修改. 创建详情页 虽然项目中有Detail视图,但是我们无法查看学生的选课信息.所以修改Detail视图页如下,添加Enrollments信息. 1 @model ContosoUniversity.Models.Student 2 3 @{ 4 ViewBag.Title = "Details"; 5 } 6 7 <h2>Details</h2> 8 9 <div> 10

增删查改实现多文件上传, 采用ASP.NET MVC 5 and EF 6

public class Support { public int SupportId { get; set; } [Required(ErrorMessage="please enter your Name")] [Display(Name="Name")] [MaxLength(100)] public string Name { get; set; } [Required(ErrorMessage="plese enter summary"

ASP.NET MVC- 简单的增删查改

项目还是用平时习惯的三层架构,然后WEB端是MVC的.好了就这么简单. 一.显示数据列表 取数据,将DataTable转成LIST类形,然后放到ViewBag里 public ActionResult Index() { List<Package.Model.Message> lists = new List<Package.Model.Message>(); MessageDal message = new MessageDal(); DataSet ds = message.G

[Asp.net MVC]Asp.net MVC5系列——实现编辑、删除与明细信息视图

目录 概述 实现信息的明细视图 实现信息的编辑视图 实现信息的删除视图 总结 系列文章 [Asp.net MVC]Asp.net MVC5系列——第一个项目 [Asp.net MVC]Asp.net MVC5系列——添加视图 [Asp.net MVC]Asp.net MVC5系列——添加模型 [Asp.net MVC]Asp.net MVC5系列——从控制器访问模型中的数据 [Asp.net MVC]Asp.net MVC5系列——添加数据 [Asp.net MVC]Asp.net MVC5系列

ASP.Net增删查改写的一个通讯录系统---ShinePans

1.开发环境 vs 2013,sqlserver 2012,win 8.1x64,C#语言,.net 4.5 2.更能说明 通讯录人性化的增删查改 3.网页效果 1.主页: 2. 查看全部联系人 3.查找职业为学生的联系人: 4.查找指定姓名的联系人: 5.添加联系人: 6.添加后: 7.更新联系人: 8.更新前: 9.更新后: 10.删除联系人: 11.删除前: 12.删除后: 13.关于: 4.关键代码: default.aspx: <%@ Page Title="Delete&quo

Asp.Net MVC5入门学习系列④

原文:Asp.Net MVC5入门学习系列④ 添加Model且简单的使用EF 对于EF(EntityFramework)不了解的朋友可以去百度文科或者在园子里搜一些简资源看下,假如和我一样知道EF的概念,那么就知道EF有一个code first的特性,什么意思呢!说的通俗简单明了点就是:通过代码映射到数据库!有朋友会说这里不是添加Model说这个EF干啥呢!说这个code first呢就是我们在一会添加Model的同时我打算利用EF的code first特性把我们的Model映射到数据库,这样我