初入码田--ASP.NET MVC4 Web应用开发之二 实现简单的增删改查
初入码田--ASP.NET MVC4 Web应用之创建一个空白的MVC应用程序
初入码田--ASP.NET MVC4 Web应用开发之一 实现简单的登录
2016-07-29
一、创建M002AdminDemo.cs
右键【Models】-->添加-->类
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web; namespace Ddup.Models
{
/// <summary>
/// 管理员模型演示
/// </summary>
public class M002AdminDemo
{
/// <summary>
/// 定义的一个查询所有管理员的方法
/// </summary>
/// <returns></returns>
public static IEnumerable<T001Admin> GetAll()
{
DdupEntities db = new DdupEntities();
return db.T001Admin;
}
/// <summary>
/// 定义的一个根据id查找对应管理员的方法
/// </summary>
/// <param name="id"></param>
/// <returns></returns>
public static T001Admin GetById(int id)
{
DdupEntities db = new DdupEntities();
return db.T001Admin.FirstOrDefault(m => m.Id == id);
}
}
}
二、创建Vm002新增管理员视图模型.cs
右键【ViewModel】-->添加-->类
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web; //调用数据注释所需程序集
using System.ComponentModel.DataAnnotations; namespace Ddup.Models.ViewModel
{
public class Vm002新增管理员视图模型
{
//required表示必填项,ErrorMessage返回错误信息
[Required(ErrorMessage = "{0},不能为空")]
//stringlength定义输入字符的范围(max,min,error)
[StringLength(, MinimumLength = , ErrorMessage = "请输入{2}至{1}个字符")]
//定义属性在页面显示时的名称
[Display(Name = "账号")]
public string Account { get; set; } [Required(ErrorMessage = "{0},不能为空")]
[StringLength(, MinimumLength = , ErrorMessage = "请输入{2}至{1}个字符")]
[Display(Name = "密码")]
public string Password { get; set; } [Required(ErrorMessage = "{0},不能为空")]
[StringLength(, MinimumLength = , ErrorMessage = "请输入{2}至{1}个字符")]
[Display(Name = "姓名")]
public string Name { get; set; } /// <summary>
/// 定义的 Vm002新增管理员视图模型 该类的一个空构造函数
/// </summary>
public Vm002新增管理员视图模型()
{
Account = "";
Password = "";
//为了后面(Create)演示,此处设置Name初始化值为Ddup
Name = "Ddup";
} /// <summary>
/// 定义了将新增数据通过EF,插入到数据库中的方法
/// </summary>
public void Save()
{
using (DdupEntities db = new DdupEntities())
{
var t001 = new T001Admin()
{
Account=this.Account,
Password=this.Password,
Name=this.Name
};
db.T001Admin.Add(t001);
db.SaveChanges();
}
}
}
}
三、创建C02AdminController.cs控制器
右键【Controllers】-->添加控制器-->空的MVC5控制器
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.Mvc; using Ddup.Models;
using Ddup.Models.ViewModel; namespace Ddup.Controllers
{
public class C02AdminController : Controller
{
/// <summary>
/// 使用GetAll()方法,返回所有管理员信息
/// </summary>
/// <returns></returns>
public ActionResult Index()
{
return View(M002AdminDemo.GetAll());
} /// <summary>
/// 使用GetById()方法,通过传递的id来获取对应管理员的详细信息
/// </summary>
/// <param name="id"></param>
/// <returns></returns>
public ActionResult Details(int id)
{
var model = M002AdminDemo.GetById(id);
if (model == null) return View("Error");
return View(model);
} /// <summary>
/// 定义get的新增action,调用 Vm002新增管理员视图模型 的空构造函数,初始化
/// </summary>
/// <returns></returns>
public ActionResult Create()
{
//通过此action,后面再新增页面Name的初始值会和 Vm002新增管理员视图模型 的空构造函数中
//所定义的初始化值一样。
return View(new Vm002新增管理员视图模型());
} /// <summary>
/// 定义的post的新增action,在View中表单提交方式为POST时,将通过此action执行操作
/// </summary>
/// <param name="model"></param>
/// <returns></returns>
[HttpPost]
public ActionResult Create(Vm002新增管理员视图模型 model)
{
//try,catch异常捕获
try
{
//判断模型状态是否有效,此处根据在 Vm002新增管理员视图模型 中对各个属性的数据注释来判断,对应输入的值是否有效
if (ModelState.IsValid)
{
//调用 Vm002新增管理员视图模型 中所定义的保存方法Save()
model.Save();
//return View("Index");
//return Redirect("~/C02Admin/Index");
return RedirectToAction("Index");
}
}
catch (Exception ex)
{
//将捕获的异常信息添加到""中,或者注明关键字(如:"Name"),将来在View中对应输出错误信息
ModelState.AddModelError("", ex.Message);
}
return View(model);
} public ActionResult Edit(int id)
{
var model = M002AdminDemo.GetById(id);
if (model == null) return View("Error"); //前台与后台之间的传值方法之一ViewData
//将通过id找到的模型数据,传递与视图数据关联的模型
ViewData.Model = model;
return View(model);
} [HttpPost]
public ActionResult Edit(int id, FormCollection collection)
{
try
{
if (ModelState.IsValid)
{
DdupEntities db = new DdupEntities();
var model = db.T001Admin.FirstOrDefault(m => m.Id == id); #region 1.0 更新model的关键字字段值(所有) string[] strArr = collection.AllKeys;
TryUpdateModel(model, strArr); #endregion #region 2.0 更新model的关键字字段值(选择要更新关键字字段) //TryUpdateModel(model, new string[] {"Account","Password","Name" });
#endregion db.SaveChanges();
return RedirectToAction("Index");
}
}
catch (Exception ex)
{
ModelState.AddModelError("", ex.Message);
}
return View();
} public ActionResult Delete(int id)
{
try
{
DdupEntities db = new DdupEntities(); ;
var t001 = db.T001Admin.FirstOrDefault(m => m.Id == id);
if (t001 != null)
{
db.T001Admin.Remove(t001);
db.SaveChanges();
return RedirectToAction("Index");
}
}
catch (Exception ex)
{
ModelState.AddModelError("", ex.Message);
}
return View();
}
}
}
四、创建对应的视图
添加返回所有管理员的Index视图
添加返回对应id的管理员Details视图
添加新增视图
添加编辑视图
五、测试下我们所创建的增删改查功能吧
本人属于初学者,如果有何不足,还请见谅,也希望大家多多给意见,谢谢!!!
=================================================================================================
作者:程程程
出处:http://rcddup.cnblogs.com
本文由程程程原创,并发布到博客园,欢迎转载,但必须在文章页面明显位置写明作者和出处,非常感谢!
初入码田--ASP.NET MVC4 Web应用开发之二 实现简单的增删改查的更多相关文章
- 初入码田--ASP.NET MVC4 Web应用开发之一 实现简单的登录
初入码田--ASP.NET MVC4 Web应用之创建一个空白的MVC应用程序 初入码田--ASP.NET MVC4 Web应用开发之二 实现简单的增删改查 2016-07-24 一.创建T4模板,建 ...
- 初入码田--ASP.NET MVC4 Web应用之创建一个空白的MVC应用程序
初入码田--ASP.NET MVC4 Web应用开发之一 实现简单的登录 初入码田--ASP.NET MVC4 Web应用开发之二 实现简单的增删改查 2016-07-29 在此之前,需要一台电脑( ...
- Web API开发实例——对产品Product进行增删改查
1.WebApi是什么 ASP.NET Web API 是一种框架,用于轻松构建可以由多种客户端(包括浏览器和移动设备)访问的 HTTP 服务.ASP.NET Web API 是一种用于在 .NET ...
- 通过flask实现web页面简单的增删改查bootstrap美化版
通过flask实现web页面简单的增删改查bootstrap美化版 项目目录结构 [root@node1 python]# tree -L 2 . ├── animate.css ├── fileut ...
- 通过flask实现web页面简单的增删改查
通过flask实现web页面简单的增删改查 # 1.后台程序falsk_web01.py #coding:utf-8 from flask import Flask,render_template,r ...
- Java web 简单的增删改查程序(超详细)
就是简单的对数据进行增删改查.代码如下: 1.bean层:用来封装属性及其get set方法 toString方法,有参构造方法,无参构造方法等. public class Bean { privat ...
- mysql实现简单的增删改查,放入xmapp自带数据库中
1.mysql概念:SQL-Structured Query Language,是一种特殊的语言,专用于操作关系型数据库服务器中的数据,所有的SQL语句分为四类: (1)DDL(2)DQL(3)DML ...
- spring boot web开发 简单的增删改查和spring boot 自带的Junit测试 案例
创建 web项目 配置pom.xml文件 ------相当于jar包 配置application.yml -----配置文件(spring数据库连接.server服务.logging日志等) 创建 ...
- ASP.NET MVC5+EF6+EasyUI 后台管理系统(5)-EF增删改查
系列目录 前言 为了符合后面更新后的重构系统,文章于2016-11-1日重写 回顾上一节的解决方案,我们看出了解决方案中类库的关系 这里要说明一点MVC!=三层 他们大约是这样的一种关系 代码实现 上 ...
随机推荐
- idea 搜索不到前端的ajax controller接口的原因
这是因为我把 web 目录设置成了 Excluded ,没有索引所以找不到了 参考: https://www.cnblogs.com/kinome/p/9991022.html IDEA 出现 upd ...
- 图解SSH原理
1. 初见SSH SSH是一种协议标准,其目的是实现安全远程登录以及其它安全网络服务. SSH仅仅是一协议标准,其具体的实现有很多,既有开源实现的OpenSSH,也有商业实现方案.使用范围最广泛的当然 ...
- ubuntu下安装pip install mysqlclient 报错 command "python setup.py egg_info" failed with error.....解决方案
我的环境: ubuntu 1604 版本, 在黑屏终端已经安装了django和virtualenv虚拟环境, 在创建了django的models后开始迁移的操作, 出现错误, 错误代码最后如题目 可以 ...
- Mysql试题集锦
1.一张表,里面有 ID 自增主键,当 insert 了 17 条记录之后,删除了第 15,16,17 条记录,再把 Mysql 重启,再 insert 一条记录,这条记录的 ID 是 18 还是 1 ...
- SQL Server Management Studio 键盘快捷键
光标移动键盘快捷键 操作 SQL Server 2012 SQL Server 2008 R2 左移光标 向左键 向左键 右移光标 向右键 向右键 上移光标 向上键 向上键 下移光标 向下键 向下键 ...
- python魔法方法大全
1.python魔法方法详解: python魔法方法是可以修改重载的,如果你的对象实现(重载)了这些方法中的某一个,那么这个方法就会在特殊的情况下被 Python 所调用,你可以定义自己想要的行为,而 ...
- Gitlab 403 forbidden 并发引起IP被封
问题 在工作中自搭建的Gitlab.但今天打开页面的时候显示的是空白页面,上面还有一次文本Forbidden. 原因 Gitlab使用rack_attack做了并发访问的限制. 解决方案 将Gitla ...
- jsp servlet路径问题
最近做小作业时饱受路径问题的困扰,记录一下: 当工程目录如上所示时,路径应该这么写: 情况1:根目录下 login.jsp中的表单提交给Servlet时,可以直接写Servlet名: <form ...
- 0.前言 three.js 简介
前言 前段时间开始接触three.js本来以为会很简单但是真正开始学习的时候才发现事情并不是我想象的那么容易,three.js的学习资料非常的少稍微好一点的资料就是收费的,给three.js的学习带来 ...
- L2 Helios OPcodez
天堂2 Helios太阳神版本 的客户端和服务端封包 *********************** Client ***********************00 SendLogOut01 Req ...