linq to sql DAL
2013-12-23 10:19
225 查看
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Data.Linq;
namespace DAL
{
public class LinQBaseDao
{
/// <summary>
/// 查询所有的记录
/// </summary>
/// <typeparam name="T"></typeparam>
/// <param name="dc"></param>
/// <returns></returns>
public IEnumerable<T> Query<T>(DataContext dc) where T:class
{
return dc.GetTable<T>().AsEnumerable<T>() ;
}
/// <summary>
/// 按条件查询记录
/// </summary>
/// <typeparam name="T"></typeparam>
/// <param name="dc"></param>
/// <param name="fun"></param>
/// <returns></returns>
public IEnumerable<T> Query<T>(DataContext dc, Func<T,bool> fun) where T : class
{
return dc.GetTable<T>().Where<T>(fun).AsEnumerable<T>();
}
/// <summary>
/// 查询单条 返回实体
/// </summary>
/// <typeparam name="T"></typeparam>
/// <param name="fun"></param>
/// <returns></returns>
public T Single<T>(DataContext dc,Func<T, bool> fun) where T : class
{
return dc.GetTable<T>().Single<T>(fun);
}
/// <summary>
/// 添加一条记录
/// </summary>
/// <typeparam name="T"></typeparam>
/// <param name="dc"></param>
/// <param name="tentity"></param>
public void InsertOne<T>(DataContext dc, T tentity) where T : class
{
var table = dc.GetTable<T>();
table.InsertOnSubmit(tentity);
dc.SubmitChanges();
}
/// <summary>
/// 添加多条记录
/// </summary>
/// <typeparam name="T"></typeparam>
/// <param name="dc"></param>
/// <param name="tentitys"></param>
public void InsertToMany<T>(DataContext dc, IEnumerable<T> tentitys) where T : class
{
var table = dc.GetTable<T>();
table.InsertAllOnSubmit(tentitys);
dc.SubmitChanges();
}
/// <summary>
/// 删除单条数据
/// </summary>
/// <typeparam name="T"></typeparam>
/// <param name="dc"></param>
/// <param name="tentity"></param>
/// <param name="fun"></param>
public void DeleteOne<T>(DataContext dc, T tentity, Func<T, bool> fun) where T : class
{
var table = dc.GetTable<T>();
var result = table.Where<T>(fun).First<T>();
table.DeleteOnSubmit(result);
dc.SubmitChanges();
}
/// <summary>
/// 按条件删除多条数据
/// </summary>
/// <typeparam name="T"></typeparam>
/// <param name="dc"></param>
/// <param name="tentitys"></param>
/// <param name="fun"></param>
public void DeleteToMany<T>(DataContext dc, IEnumerable<T> tentitys, Func<T, bool> fun) where T : class
{
var table = dc.GetTable<T>();
var result = table.Where<T>(fun).AsEnumerable<T>();
table.DeleteAllOnSubmit<T>(result);
dc.SubmitChanges();
}
/// <summary>
/// 删除多条数据
/// </summary>
/// <typeparam name="T"></typeparam>
/// <param name="dc"></param>
/// <param name="tentitys"></param>
public void DeleteToManyByCondition<T>(DataContext dc, IEnumerable<T> tentitys) where T : class
{
var table = dc.GetTable<T>();
table.DeleteAllOnSubmit<T>(tentitys);
dc.SubmitChanges();
}
/// <summary>
/// LINQ更新方法
/// </summary>
/// <typeparam name="T"></typeparam>
/// <param name="dc"></param>
/// <param name="fun"></param>
/// <param name="tentity"></param>
/// <param name="action"></param>
public void Update<T>(DataContext dc, Func<T, bool> fun, T tentity, Action<T> action) where T : class
{
var table = dc.GetTable<T>().Single<T>(fun);
//var table = dc.GetTable<T>().Where<T>(fun).Single<T>();
action(table);
dc.SubmitChanges();
}
}
}
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Data.Linq;
namespace DAL
{
public class LinQBaseDao
{
/// <summary>
/// 查询所有的记录
/// </summary>
/// <typeparam name="T"></typeparam>
/// <param name="dc"></param>
/// <returns></returns>
public IEnumerable<T> Query<T>(DataContext dc) where T:class
{
return dc.GetTable<T>().AsEnumerable<T>() ;
}
/// <summary>
/// 按条件查询记录
/// </summary>
/// <typeparam name="T"></typeparam>
/// <param name="dc"></param>
/// <param name="fun"></param>
/// <returns></returns>
public IEnumerable<T> Query<T>(DataContext dc, Func<T,bool> fun) where T : class
{
return dc.GetTable<T>().Where<T>(fun).AsEnumerable<T>();
}
/// <summary>
/// 查询单条 返回实体
/// </summary>
/// <typeparam name="T"></typeparam>
/// <param name="fun"></param>
/// <returns></returns>
public T Single<T>(DataContext dc,Func<T, bool> fun) where T : class
{
return dc.GetTable<T>().Single<T>(fun);
}
/// <summary>
/// 添加一条记录
/// </summary>
/// <typeparam name="T"></typeparam>
/// <param name="dc"></param>
/// <param name="tentity"></param>
public void InsertOne<T>(DataContext dc, T tentity) where T : class
{
var table = dc.GetTable<T>();
table.InsertOnSubmit(tentity);
dc.SubmitChanges();
}
/// <summary>
/// 添加多条记录
/// </summary>
/// <typeparam name="T"></typeparam>
/// <param name="dc"></param>
/// <param name="tentitys"></param>
public void InsertToMany<T>(DataContext dc, IEnumerable<T> tentitys) where T : class
{
var table = dc.GetTable<T>();
table.InsertAllOnSubmit(tentitys);
dc.SubmitChanges();
}
/// <summary>
/// 删除单条数据
/// </summary>
/// <typeparam name="T"></typeparam>
/// <param name="dc"></param>
/// <param name="tentity"></param>
/// <param name="fun"></param>
public void DeleteOne<T>(DataContext dc, T tentity, Func<T, bool> fun) where T : class
{
var table = dc.GetTable<T>();
var result = table.Where<T>(fun).First<T>();
table.DeleteOnSubmit(result);
dc.SubmitChanges();
}
/// <summary>
/// 按条件删除多条数据
/// </summary>
/// <typeparam name="T"></typeparam>
/// <param name="dc"></param>
/// <param name="tentitys"></param>
/// <param name="fun"></param>
public void DeleteToMany<T>(DataContext dc, IEnumerable<T> tentitys, Func<T, bool> fun) where T : class
{
var table = dc.GetTable<T>();
var result = table.Where<T>(fun).AsEnumerable<T>();
table.DeleteAllOnSubmit<T>(result);
dc.SubmitChanges();
}
/// <summary>
/// 删除多条数据
/// </summary>
/// <typeparam name="T"></typeparam>
/// <param name="dc"></param>
/// <param name="tentitys"></param>
public void DeleteToManyByCondition<T>(DataContext dc, IEnumerable<T> tentitys) where T : class
{
var table = dc.GetTable<T>();
table.DeleteAllOnSubmit<T>(tentitys);
dc.SubmitChanges();
}
/// <summary>
/// LINQ更新方法
/// </summary>
/// <typeparam name="T"></typeparam>
/// <param name="dc"></param>
/// <param name="fun"></param>
/// <param name="tentity"></param>
/// <param name="action"></param>
public void Update<T>(DataContext dc, Func<T, bool> fun, T tentity, Action<T> action) where T : class
{
var table = dc.GetTable<T>().Single<T>(fun);
//var table = dc.GetTable<T>().Where<T>(fun).Single<T>();
action(table);
dc.SubmitChanges();
}
}
}
相关文章推荐
- linq to sql DAL
- 一步一步学Linq to sql(一):预备知识
- LinqToSql 动态查询条件,join, isnull 综合示例
- LINQ TO SQL 真的要玩完了? (翻译的一篇InfoQ的文章)
- LINQ to SQL (Part 5 - 使用ASP:LinqDataSource Control绑定 UI )
- 代替Linq to SQL----存储过程
- linq to sql 分页 的几种方法
- LINQ to SQL (Group By/Having/Count/Sum/Min/Max/Avg操作符)
- 一步一步学Linq to sql(五):存储过程
- 在.NET3.5平台上使用LinQ to SQL + NBear 创建三层WEB应用
- (转)ADO.net,Linq to SQL和Entity Framework性能实测分析
- LINQ体验(7)--LINQ to SQL语句之Group By/Having和Exists/In/Any/All/Conta...
- LINQ to SQL可视化调试工具
- LINQ to SQL语句之Where/Select/Distinct
- 在Linq to Sql中管理并发更新时的冲突(2):引发更新冲突
- LINQ to SQL语句之Insert/Update/Delete操作
- linq to sql生成not in语句的小技巧
- 在LINQ to SQL中使用Translate方法以及修改查询用SQL
- ScottGu之博客翻译-第6部分-用存储过程检索数据-LINQ to SQL (Part 6 - Retrieving Data Using Stored Procedures)
- ASP.NET MVC Tip #23 – 使用 POCO LINQ to SQL 实体