zoukankan      html  css  js  c++  java
  • MVC ---- EF4.0和EF5.0增删改查的写法区别及执行Sql的方法

    EF4.0和EF5.0增删改查的写法区别
    public T AddEntity(T entity) 
    {
        //EF4.0的写法  
        添加实体
        //db.CreateObjectSet<T>().AddObject(entity);
        //EF5.0的写法
        db.Entry<T>(entity).State = EntityState.Added;
        //下面的写法统一
        db.SaveChanges();
        return entity;
    }
    public bool UpdateEntity(T entity)
    {
        //EF4.0的写法
        //db.CreateObjectSet<T>().Addach(entity);
        //db.ObjectStateManager.ChangeObjectState(entity, EntityState.Modified);
        //EF5.0的写法 
       db.Set<T>().Attach(entity); 
       db.Entry<T>(entity).State = EntityState.Modified; 
       return db.SaveChanges() > 0; 
    }
    public bool DeleteEntity(T entity)
    {
        //EF4.0的写法 
       //db.CreateObjectSet<T>().Addach(entity);
       //db.ObjectStateManager.ChangeObjectState(entity, EntityState.Deleted);
       //EF5.0的写法
       db.Set<T>().Attach(entity);
       db.Entry<T>(entity).State = EntityState.Deleted;
       return db.SaveChanges() > 0;
    }
    
    public IQueryable<T> LoadEntities(Func<T, bool> whereLambda)
    {
        //EF4.0的写法
        //return db.CreateObjectSet<T>().Where<T>(whereLambda).AsQueryable();
        //EF5.0的写法
        return db.Set<T>().Where<T>(whereLambda).AsQueryable();
    }
    执行SQL语句
    //EF4.0的写法
    //int ExcuteSql(string strSql, ObjectParameter[] parameters);
    return EFContextFactory.GetCurrentDbContext().ExecuteFunction(strSql, parameters);
    //EF5.0的写法
     int ExcuteSql(string strSql, DbParameter[] parameters);
    return DEFContextFactory.GetCurrentDbContext().ExecuteSqlCommand(strSql, parameters);

    来源:http://blog.csdn.net/xjn030594/article/details/8946996

  • 相关阅读:
    Spring浅谈
    struts浅谈
    Tomcat启动发生的那些事儿
    sizeof的用法
    栈应用之括号匹配
    条件编译
    MySQL数据库常用命令
    快速排序
    分页查询的那些坑和各种技巧
    国外程序员收集整理的 PHP 资源大全
  • 原文地址:https://www.cnblogs.com/youmingkuang/p/6484694.html
Copyright © 2011-2022 走看看