1.Add

 #region 1.1 新增学生信息(定义成Int类型,返回受影响的行数)
/// <summary>
/// 新增学生信息
/// </summary>
/// <param name="stu"></param>
/// <returns></returns>
public int Add(Studnet stu)
{
//把对象加入到EF上下文中,并获取对象的状态管理对象
DbEntityEntry<Studnet> entry = db.Entry<Studnet>(stu); //把状态改为Added
//要引入System.Data.Entity
entry.State = System.Data.EntityState.Added; //保存到数据库
return db.SaveChanges(); }
#endregion

2.Delete

2.1根据用户ID来删除

 #region 2.0 根据学生的ID来删除
/// <summary>
/// 根据学生的ID来删除
/// </summary>
/// <param name="id"></param>
/// <returns></returns>
public int Delete(int id)
{
Studnet stu = new Studnet() { s_ID = id };
//删除传过来的ID
//DbEntityEntry<Studnet> stu= db.Studnets.Where(s => s.s_ID == id) as DbEntityEntry<Studnet>;
DbEntityEntry<Studnet> entry = db.Entry<Studnet>(stu);
//把状态改为deleted
entry.State = System.Data.EntityState.Deleted; //保存到数据库
return db.SaveChanges();
}
#endregion

2.2根据条件来删除

其实就是在where方法中传入了一个lambda表达式,而lambda表达式本质上就是一个匿名函数。

 #region 2.1 根据条件来删除
/// <summary>
/// 根据条件来删除
/// (给出任意条件,然后删除)
/// </summary>
/// <returns></returns>
public int DeleteBy(System.Linq.Expressions.Expression<Func<Studnet, bool>> deleteWhere)
{
//查询出要删除的数据
List<Studnet> stuList = db.Studnets.Where(deleteWhere).ToList();
//循环删除
stuList.ForEach(u => db.Studnets.Remove(u)); //保存到数据库
return db.SaveChanges(); }
#endregion

3.Modify

 #region 3.0 修改
/// <summary>
/// 修改
/// 要告诉程序,哪个属性改了。这里添加一个可变参数数组
/// </summary>
/// <param name="stu"></param>
/// <returns></returns>
public int Modify(Studnet stu, params string[] parmeters)
{
//把对象加入到EF容器,并获取状态管理对象
DbEntityEntry<Studnet> entry = db.Entry<Studnet>(stu); //对象的状态改为Unchanged
entry.State = System.Data.EntityState.Unchanged;
foreach (string parms in parmeters)
{
entry.Property(parms).IsModified = true;
} return db.SaveChanges();
}
#endregion

测试修改:

  /// <summary>
/// 修改的测试
/// </summary>
public Student()
{
//把Id为1的学生的名字改为xxxxxxxxxxx
Studnet stu = new Studnet() { s_ID=,s_Name="xxxxxxxxxxx"};
//改哪个实体,改哪个属性
this.Modify(stu, "s_Name");
}

Test Modify

测试删除:

 /// <summary>
/// 删除的测试
/// </summary>
public Student()
{ this.DeleteBy(u => u.s_ID == );
}

Test Delete

4. Query

4.1根据条件查询

 #region 4.1  根据条件查询
/// <summary>
/// 根据条件查询
/// 查询的结果一般都是集合,所以返回值类型为泛型集合
/// </summary>
/// <returns></returns>
public List<Studnet> GetStudentList(System.Linq.Expressions.Expression<Func<Studnet, bool>> whereQuery)
{
return db.Studnets.Where(whereQuery).ToList();
}
#endregion

4.2根据条件查询,查询完之后,还要分组。

 /// <summary>
/// 根据条件查询,查询玩之后,还要分组
/// </summary>
/// <param name="whereQuery"></param>
/// <param name="QroupByQuery"></param>
/// <returns></returns>
public List<Studnet> GetStudentList<Tkey>(System.Linq.Expressions.Expression<Func<Studnet, bool>> whereQuery, System.Linq.Expressions.Expression<Func<Studnet, Tkey>> QroupByQuery)
{
return db.Studnets.Where(whereQuery).OrderBy(QroupByQuery).ToList();
}

测试根据条件查询:

  public Student()
{
this.GetStudentList(u => u.s_ID == && u.s_Sex == "女"); }

根据条件查询

测试根据条件查询,查询完之后再根据条件分组:

  public Student()
{ this.GetStudentList(u => u.s_ID >= , u => u.s_Sex);
}

查询并分组

4.3分页查询

 #region 4.2 分页查询
/// <summary>
/// 分页查询
/// 先排序,再分页
/// </summary>
/// <param name="pageIndex">页码</param>
/// <param name="pageSize">页容量</param>
/// <param name="orderLambda">排序条件</param>
/// <returns></returns>
public List<Studnet> GetPagedList<Tkey>(int pageIndex, int pageSize, Expression<Func<Studnet, Tkey>> orderLambda)
{
//分页:一定要注意,Skip之前一定要OrderBy,因为到时候会生成一个RowNum的分页查询(通过SQL ServerProfier侦听到的)
return db.Studnets.OrderBy(orderLambda).Skip((pageIndex - ) * pageSize).Take(pageSize).ToList();
}
#endregion

EF增删查改(三)------终极版的更多相关文章

  1. EF增删查改加执行存储过程和sql语句,多种方法汇总

    ActionUrl c = new ActionUrl() { ActionName="test", RequestUrl="/123/123", SubTim ...

  2. MVC学习之路(1) EF 增删查改合集

    首先再Model中创建一个类[WMBlogDB] public class WMBlogDB : DbContext { //连接字符串. public WMBlogDB() : base(" ...

  3. EF增删查改基类

    /// <summary> /// EF DAL CURD基类 /// </summary> /// <typeparam name="T">& ...

  4. Ext3.4实现增删查改(form版)

    var TaskPolicyStore = new Ext.data.JsonStore( {    autoLoad : false,    url : 'PolicyServlet?method= ...

  5. Entity Framework(三)---FluentAPI和增删查改

    一.FluentAPI: 1.基本配置: namespace ConsoleApp14.ModelConfig { public class PersonConfig: EntityTypeConfi ...

  6. EF各版本增删查改及执行Sql语句

    自从我开始使用Visual Studio 也已经经历了好几个版本了,而且这中间EF等框架的改变也算是比较多的.本篇文章记录下各个版本EF执行Sql语句和直接进行增删查改操作的区别,方便自己随时切换版本 ...

  7. 3.EF 6.0 Code-First实现增删查改

    原文链接:http://www.c-sharpcorner.com/UploadFile/3d39b4/crud-operations-using-entity-framework-5-0-code- ...

  8. MongoDB入门学习(三):MongoDB的增删查改

            对于我们这样的菜鸟来说,最重要的不是数据库的管理,也不是数据库的性能,更不是数据库的扩展,而是怎么用好这款数据库,也就是一个数据库提供的最核心的功能,增删查改.         由于M ...

  9. [课本]JDBC课程6--使用JDBC的DAO模块化--完成数据库的增删查改_工具类JDBCTools四个(Preparedstatement)功能模块的敲定版

    (课本P273-任务九) /**DAO: Data Access Object * 为什么用: 实现功能的模块化,更有利于代码的维护和升级 * 是什么: 访问数据信息的类,包含对数据的CRUD(cre ...

随机推荐

  1. Spark随机森林实现学习

    前言 最近阅读了spark mllib(版本:spark 1.3)中Random Forest的实现,发现在分布式的数据结构上实现迭代算法时,有些地方与单机环境不一样.单机上一些直观的操作(递归),在 ...

  2. 每日英语:The Secret About Online Ad Traffic: One-Third Is Bogus

    Billions of dollars are flowing into online advertising. But marketers also are confronting an uncom ...

  3. [转] IE6中请求莫名中断

    这两天碰到的问题,IE6下某个js生成的a节点,设置了href="javascript:;",点击时触一个ajax请求,但在IE6下就是无法执行succese里的内容,所以就用se ...

  4. PMBOK/CMM/CMMI/OPM3

    1968年为了解决大型软件项目的软件危机,北大西洋公约组织(NATO)提出了“软件工程”这一术语,以改进软件开发设计过程. 1969年美国项目管理协会(PMI)组织成立,从1981年起经过30年的努力 ...

  5. [转]Android 超高仿微信图片选择器 图片该这么加载

    快速加载本地图片缩略图的方法: 原文地址:Android 超高仿微信图片选择器 图片该这么加载 其示例代码下载: 仿微信图片选择器 ImageLoader

  6. jedis:exception is java.lang.VerifyError: Bad type on operand stack

    项目中需要用到缓存,经过比较后,选择了redis,客户端使用jedis连接,也使用到了spring提供的spring-data-redis.配置正确后启动tomcat,发现如下异常: ======== ...

  7. C#读取图片Exif信息

    Exif是可交换图像文件的缩写,是专门为数码相机的照片设定的,可以记录数码照片的属性和拍摄数据 ////调用 //string strFile="fffff.jpg";//文件名 ...

  8. 【汇总】iOS开发及Xcode使用中遇到的一些报错问题汇总

    这里整合下在开发过程中遇到过的一些报错问题和解决办法:(今天开始逐渐增加)   Xcode编译错误集锦:http://www.cnblogs.com/ios-wmm/p/3402261.html   ...

  9. SQL数据库对于保存特殊字符的解决办法

    数据库的Char.Vachar类型可以兼容汉字,但特殊字符不行,在保存包含有特殊字符的字符串.正文时,会将特殊符号替换成一个”?”号. 例如: “基础教育课程手机报•特刊” == > “基础教育 ...

  10. 二十九、EFW框架开发的系统支持SaaS模式和实现思路

    回<[开源]EFW框架系列文章索引>        EFW框架源代码下载V1.3:http://pan.baidu.com/s/1c0dADO0 EFW框架实例源代码下载:http://p ...