using DAL; using Model; using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; namespace BLL { public class InfoManage { private BaseDal db; public InfoManage(BaseDal dal) { this.db = dal; } public InfoManage() { this.db = new BaseDal(); } public bool Add(Info lst) { db.BeginTranscation(); db.SaveOrUpdate(lst, true); return db.Commit() > 0; } public List<Info> GetList() { return db.GetEntity<Info>().ToList(); } } }
ADO.NET Entity Framework 是微軟以 ADO.NET 爲基礎所發展出來的對象關係對應 (O/R Mapping) 解決方案,早期被稱爲 ObjectSpace。sql
1.搭建EF環境數據庫
在DAL層添加項目ADO.NET 實體數據庫模型app
在Model層添加EF 5.x DbContext生成器ide
修改inputFile的值this
DAL 代碼spa
using System; using System.Collections.Generic; using System.Data; using System.Data.Common; using System.Data.SqlClient; using System.Linq; using System.Linq.Expressions; using System.Text; using System.Threading.Tasks; namespace DAL { public class BaseDal : IDisposable { private TestEntities db = new TestEntities(); private bool isTransaction = false; public IQueryable<T> GetEntity<T>() where T : class { return db.Set<T>().AsNoTracking().AsQueryable<T>(); } /// <summary> /// 添加 /// </summary> /// <typeparam name="T"></typeparam> /// <param name="lst"></param> /// <returns></returns> public int Add<T>(List<T> lst, bool isCommit = true) where T : class { foreach (var item in lst) { db.Entry<T>(item).State = System.Data.EntityState.Added; } if (isCommit && !isTransaction) return db.SaveChanges(); else return 0; } /// <summary> /// 根據條件刪除 /// </summary> /// <typeparam name="T"></typeparam> /// <param name="predicate"></param> /// <returns></returns> public bool DeleteByCondition<T>(Expression<Func<T, bool>> predicate, bool isCommit = true) where T : class { db.Set<T>().Where<T>(predicate).ToList<T>().ForEach(d => db.Entry<T>(d).State = System.Data.EntityState.Deleted); if (isCommit && !isTransaction) return db.SaveChanges() > 0; else return false; } public bool UpdateByCondition<T>(Action<T> updateExpression, Expression<Func<T, bool>> predicate, bool isCommit = true) where T : class { var lst = db.Set<T>().Where<T>(predicate).ToList<T>(); lst.ForEach(item => { updateExpression(item); db.Entry<T>(item).State = System.Data.EntityState.Modified; }); if (isCommit && !isTransaction) return db.SaveChanges() > 0; else return false; } public bool SaveOrUpdate<T>(T entity, bool isAdd = false, bool isCommit = true) where T : class { if (isAdd) db.Set<T>().Add(entity); else db.Entry(entity).State = System.Data.EntityState.Modified; if (isCommit && !isTransaction) return db.SaveChanges() > 0; else return false; } public bool SaveOrUpdateForList<T>(List<T> entities, bool isAdd = false, bool isCommit = true) where T : class { foreach (T entity in entities) { if (isAdd) db.Set<T>().Add(entity); else db.Entry(entity).State = System.Data.EntityState.Modified; } if (isCommit && !isTransaction) return db.SaveChanges() > 0; else return false; } public int ExecuteSqlCommand(string sql, bool isCommit = true) { db.Database.ExecuteSqlCommand(sql); if (isCommit && !isTransaction) return db.SaveChanges(); else return 0; } public int ExecuteSqlCommand(string sql, bool isCommit, params object[] parameters) { db.Database.ExecuteSqlCommand(sql, parameters); if (isCommit && !isTransaction) return db.SaveChanges(); return 0; } /// <summary> /// 執行存儲過程 /// </summary> /// <typeparam name="T"></typeparam> /// <param name="ProcName"></param> /// <param name="paramsStr"></param> /// <returns></returns> public List<T> ExecPro<T>(string ProcName, object[] paramsStr) { try { string sql = "exec " + ProcName; if (paramsStr.Length > 0) { string str = string.Empty; for (int i = 0; i < paramsStr.Length; i++) { if (str != string.Empty) str += ","; str += "@p" + i.ToString(); } sql += " " + str; } return db.Database.SqlQuery<T>(sql, paramsStr).ToList(); } catch (Exception ex) { return new List<T>(); } } /// <summary> /// 執行存儲過程 無超時 /// </summary> /// <param name="ProcName"></param> /// <param name="parList"></param> public void ExecPro(string ProcName, List<SqlParameter> parList) { DbConnection conn = db.Database.Connection; if (conn.State == ConnectionState.Closed) conn.Open(); DbCommand cmd = conn.CreateCommand(); cmd.CommandType = System.Data.CommandType.StoredProcedure; cmd.CommandText = ProcName; cmd.CommandTimeout = 0; foreach (SqlParameter par in parList) { cmd.Parameters.Add(par); } cmd.ExecuteNonQuery(); } public void BeginTranscation() { isTransaction = true; } public int Commit() { if (isTransaction) { isTransaction = false; return db.SaveChanges(); } else return 0; } /// <summary> /// 執行SQL查詢語句 /// </summary> /// <typeparam name="T"></typeparam> /// <returns></returns> public List<T> FindEntityListBySql<T>(string sql) { return db.Database.SqlQuery<T>(sql).ToList<T>(); } public void Close() { if (db != null) { db.Dispose(); db = null; } } public void Dispose() { if (db != null) { db.Dispose(); db = null; } } } }
BLL 代碼3d
1 using DAL; 2 using Model; 3 using System; 4 using System.Collections.Generic; 5 using System.Linq; 6 using System.Text; 7 using System.Threading.Tasks; 8 9 namespace BLL 10 { 11 public class InfoManage 12 { 13 private BaseDal db; 14 public InfoManage(BaseDal dal) 15 { 16 this.db = dal; 17 } 18 19 public InfoManage() 20 { 21 this.db = new BaseDal(); 22 } 23 24 25 public bool Add(Info lst) 26 { 27 //db.BeginTranscation(); 28 //db.SaveOrUpdate(lst, true); 29 //return db.Commit() > 0; 30 return db.SaveOrUpdate(lst, true, true); 31 } 32 33 public bool Save(Info info) 34 { 35 return db.SaveOrUpdate(info, false, true); 36 } 37 38 39 public bool Delete(Info info) 40 { 41 return db.DeleteByCondition<Info>(e => e.Name == info.Name, true); 42 } 43 44 public List<Info> GetList() 45 { 46 return db.GetEntity<Info>().ToList(); 47 } 48 } 49 }
客戶端調用code