MVC3中EF实现的CRUD操作

 public class HomeController : Controller
{
//
// GET: /Home/
CarModelContainer db = new CarModelContainer(); #region 查询全部 +Index()
public ActionResult Index()
{ List<CarModel> list = (from c in db.CarModel select c).ToList();
//ViewData["DataList"] = list; 上下两种效果一样 都是为了传递数据到前台
return View(list); //这样传输的是强类型的数据 在前台通过Model获取
}
#endregion #region 加入信息 +Create() [HttpGet]
public ActionResult Create()
{
return View();
}
[HttpPost]
public ActionResult Create(CarModel car)
{
if (ModelState.IsValid) //后台的验证信息
{
db.CarModel.AddObject(car);
db.SaveChanges();
return RedirectToAction("Index"); }
else
{
return View(car);
} }
#endregion #region 编辑信息 +Edit()
[HttpGet]
public ActionResult Edit(int id)
{
CarModel car=(from a in db.CarModel
where a.ID==id
select a).FirstOrDefault(); if (car==null)
{
return RedirectToAction("Index"); }
return View(car);
}
[HttpPost]
public ActionResult Edit(CarModel car)
{
try
{
//第一种方式 使用LinQ查询出要编辑的对象
//CarModel model=(from a in db.CarModel
// where a.ID==car.ID
// select a).FirstOrDefault(); //另外一种方式 创建一个所以要加入的对象 car中的实体属性 系统会自己主动检索得到相应的值
CarModel model = new CarModel() { ID=car.ID};
db.CarModel.Attach(model); UpdateModel(model);
db.SaveChanges();
return RedirectToAction("index");
}
catch (Exception )
{
ModelState.AddModelError("","改动失败。请查看具体错误信息"); }
return View(car); } #endregion #region 删除信息 +Delete()
public ActionResult Delete(int id)
{
CarModel car = (from a in db.CarModel
where a.ID == id
select a).FirstOrDefault();
db.CarModel.DeleteObject(car);
db.SaveChanges();
return RedirectToAction("index");
}
#endregion }

MVC 4中EF实现的CRUD操作

 //加入实体
public bool AddEntity(Model.Customer entity)
{
Hotel.Model.HotelModelContainer db = new Model.HotelModelContainer();
db.Customer.Add(entity);
int count = db.SaveChanges();
if (count > 0)
{
return true;
}
return false; }
//删除实体
public bool DeleteEntity(Model.Customer entity)
{
Hotel.Model.HotelModelContainer db = new Model.HotelModelContainer();
Customer cus = db.Customer.Where<Customer>(c => c.ID == entity.ID).FirstOrDefault<Customer>();
if (cus != null)
{
db.Customer.Remove(cus); }
int count = db.SaveChanges();
if (count > 0)
{
return true;
}
return false;
}
//更新实体
public bool UpdateEntity(Model.Customer entity)
{
Hotel.Model.HotelModelContainer db = new Model.HotelModelContainer();
// DbEntityEntry<Customer> entry = db.Entry<Customer>(entity);
//entry.State = System.Data.EntityState.Unchanged;
//entry.Property("CustomerName").IsModified = true;
// entry.Property("Phone").IsModified = true;</span>
db.Entry(entity).State = EntityState.Modified;
int count = db.SaveChanges();
if (count > 0)
{
return true;
}
return false; } //查询数据
public IQueryable<Model.Customer> LoadEntities(Func<Model.Customer, bool> whereLambda)
{
HotelModelContainer db = new HotelModelContainer();
return db.Customer.Where<Customer>(whereLambda).AsQueryable<Customer>();
}
//查询分页数据并排序
public IQueryable<Customer> LoadPageEntities<s>(Func<Customer, bool> whereLambda, int pageSize, int pageIndex, out int totalCount, Func<Customer, s> orderByLambda)
{
HotelModelContainer db = new HotelModelContainer();
totalCount = db.Customer.Where<Customer>(whereLambda).Count();
IQueryable<Customer> customers = db.Customer.Where<Customer>(whereLambda)
.OrderBy<Customer, s>(orderByLambda)
.Skip<Customer>(pageSize * (pageIndex - 1))
.Take<Customer>(pageSize)
.AsQueryable<Customer>();
return customers;
}
//依照编号删除
public bool DeleteEntity(object Id)
{
Hotel.Model.HotelModelContainer db = new Model.HotelModelContainer();
Customer cus = db.Customer.Where<Customer>(c => c.ID == (int)Id).FirstOrDefault<Customer>();
if (cus != null)
{
db.Customer.Remove(cus); }
int count = db.SaveChanges();
if (count > 0)
{
return true;
}
return false;
}

MVC3和MVC4中CRUD操作的更多相关文章

  1. mybatis中crud操作范例

    <?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE mapper PUBLIC "-/ ...

  2. Bootstrap+Knockout.JS+ASP.Net MVC3+PetaPOCO实现CRUD操作

    Bootstrap+Knockout.JS+ASP.Net MVC3+PetaPOCO实现CRUD操作 1.需求: 1.1)页面要美观大气 1.2)前端代码要简洁清晰,要用MVC或是MVVM框架 1. ...

  3. [读书笔记] 四、SpringBoot中使用JPA 进行快速CRUD操作

    通过Spring提供的JPA Hibernate实现,进行快速CRUD操作的一个栗子~. 视图用到了SpringBoot推荐的thymeleaf来解析,数据库使用的Mysql,代码详细我会贴在下面文章 ...

  4. ASP.NET MVC4中使用NHibernate

    ASP.NET MVC4中使用NHibernate 1:下载安装NHibernate 打开 VS 2012新建一个 MVC4项目. 在项目名称上右击选择Manage NuGet Packages.你会 ...

  5. ASP.NET MVC4中对JS和CSS的引用

    https://www.cnblogs.com/madyina/p/3702314.html ASP.NET MVC4中对JS和CSS的引用又做了一次变化,在MVC3中我们这样引用资源文件: < ...

  6. 【翻译】MongoDB指南/CRUD操作(四)

    [原文地址]https://docs.mongodb.com/manual/ CRUD操作(四) 1 查询方案(Query Plans) MongoDB 查询优化程序处理查询并且针对给定可利用的索引选 ...

  7. 【翻译】MongoDB指南/CRUD操作(三)

    [原文地址]https://docs.mongodb.com/manual/ CRUD操作(三) 主要内容: 原子性和事务(Atomicity and Transactions),读隔离.一致性和新近 ...

  8. 【翻译】MongoDB指南/CRUD操作(二)

    [原文地址]https://docs.mongodb.com/manual/ MongoDB CRUD操作(二) 主要内容: 更新文档,删除文档,批量写操作,SQL与MongoDB映射图,读隔离(读关 ...

  9. 【翻译】MongoDB指南/CRUD操作(一)

    [原文地址]https://docs.mongodb.com/manual/ MongoDB CRUD操作(一) 主要内容:CRUD操作简介,插入文档,查询文档. CRUD操作包括创建.读取.更新和删 ...

随机推荐

  1. Unity3D 4.x 使用Mecanim实现动画控制

    Unity3D 4.x 版本号之后提供了一种新的动画机制Mecanim,尽管眼下还支持之前的Animation.但看到Unity3D 4.3 预览版里Sprite的动画也是基于Animator的,可知 ...

  2. Android:创建文件或文件夹以及获取sd卡根目录

    目录结构: 功能,可以根据录入的目录或者文件夹生成相应的文件或者文件夹 首先需要添加一个权限: <uses-permission android:name="android.permi ...

  3. 我的Python成长之路---第二天---Python基础(7)---2016年1月9日(晴)

    再说字符串 一.字符串的编码 字符串的编码是个很令人头疼的问题,由于计算机是美国人发明的,他们很理所当然的认为计算机只要能处理127个字母和一些符号就够用了,所以规定了一个字符占用8个比特(bit)也 ...

  4. gethostbyname()函数说明

    gethostbyname()函数说明——用域名或主机名获取IP地址 包含头文件    #include <netdb.h>    #include <sys/socket.h> ...

  5. Android Activity 常用功能设置(全屏、横竖屏等)

    Activity全屏设置 方式1:AndroidManifest.xml <activity android:name="myAcitivty"  android:theme ...

  6. boost库中thread多线程详解2——mutex与lock

    1. mutex对象类 mutex类主要有两种:独占式与共享式的互斥量.▲ 独占式互斥量:mutex: 独占式的互斥量,是最简单最常用的一种互斥量类型try_mutex: 它是mutex的同义词,为了 ...

  7. 浅谈初次搭建nginx+php+mysql遇到的问题

    先说明下我linux上的环境: nginx + php(5.5.10) + mysql 開始的源代码已经在本地写好,并调试成功(本地的环境是用XAMPP的默认配置).在把代码上传至linux上时,出现 ...

  8. 集群安装配置Hadoop具体图解

    集群安装配置Hadoop 集群节点:node4.node5.node6.node7.node8. 详细架构: node4 Namenode,secondnamenode,jobtracker node ...

  9. SQL 根据时间和打印状态抽取记录

    1.首先要是没有打印的记录. 2.其次是要按照时间,时间是要按照倒序排列. 下载文件的URL and order by 上传时间 desc *是否打印,使用字段bit,0是没有打印,1是已经打印

  10. Android-x86 4.4-r5 发布,PC 上的安卓系统

    Android x86 即运行于 x86 PC上的Android操作系统,目前已经支持大部分安卓程序. Android X86平台是由Beyounn和Cwhuang主持设计的.项目的主要目的在于为X8 ...