linq to sql
文章平均质量分 88
chungle
这个作者很懒,什么都没留下…
展开
-
LINQ to SQL语句(1)之Where
Where操作适用场景:实现过滤,查询等功能。说明:与SQL命令中的Where作用相似,都是起到范围限定也就是过滤作用的,而判断条件就是它后面所接的子句。Where操作包括3种形式,分别为简单形式、关系条件形式、First()形式。下面分别用实例举例下:1.简单形式:例如:使用where筛选在伦敦的客户var q = from c in db.Cu...原创 2009-06-10 16:21:18 · 71 阅读 · 0 评论 -
LINQ to SQL语句(15)之String
字符串(String)LINQ to SQL支持以下String方法。但是不同的是默认情况下System.String方法区分大小写。而SQL则不区分大小写。1.字符串串联(String Concatenation)var q = from c in db.Customers select new { c.CustomerID, ...原创 2009-06-10 16:46:48 · 76 阅读 · 0 评论 -
LINQ to SQL语句(16)之对象标识
对象标识运行库中的对象具有唯一标识。引用同一对象的两个变量实际上是引用此对象的同一实例。你更改一个变量后,可以通过另一个变量看到这些更改。关系数据库表中的行不具有唯一标识。由于每一行都具有唯一的主键,因此任何两行都不会共用同一键值。实际上,通常我们是将数据从数据库中提取出来放入另一层中,应用程序在该层对数据进行处理。这就是 LINQ to SQL 支持的模型。将数据作为...原创 2009-06-10 16:47:41 · 82 阅读 · 0 评论 -
LINQ to SQL语句(17)之对象加载
对象加载延迟加载在查询某对象时,实际上你只查询该对象。不会同时自动获取这个对象。这就是延迟加载。例如,您可能需要查看客户数据和订单数据。你最初不一定需要检索与每个客户有关的所有订单数据。其优点是你可以使用延迟加载将额外信息的检索操作延迟到你确实需要检索它们时再进行。请看下面的示例:检索出来CustomerID,就根据这个ID查询出OrderID。var custs = ...原创 2009-06-10 16:48:45 · 84 阅读 · 0 评论 -
LINQ to SQL语句(18)之运算符转换
运算符转换1.AsEnumerable:将类型转换为泛型 IEnumerable使用 AsEnumerable<TSource> 可返回类型化为泛型 IEnumerable 的参数。在此示例中,LINQ to SQL(使用默认泛型 Query)会尝试将查询转换为 SQL 并在服务器上执行。但 where 子句引用用户定义的客户端方法 (isValidProduct),此方法...原创 2009-06-10 16:49:20 · 67 阅读 · 0 评论 -
LINQ to SQL语句(19)之ADO.NET与LINQ to SQL
ADO.NET与LINQ to SQL它基于由 ADO.NET 提供程序模型提供的服务。因此,我们可以将 LINQ to SQL 代码与现有的 ADO.NET 应用程序混合在一起,将当前 ADO.NET 解决方案迁移到 LINQ to SQL。1.连接在创建 LINQ to SQL DataContext 时,可以提供现有 ADO.NET 连接。对 DataContext 的所...原创 2009-06-10 16:50:05 · 83 阅读 · 0 评论 -
LINQ to SQL语句(20)之存储过程
存储过程在我们编写程序中,往往需要一些存储过程,在LINQ to SQL中怎么使用呢?也许比原来的更简单些。下面我们以NORTHWND.MDF数据库中自带的几个存储过程来理解一下。1.标量返回在数据库中,有名为Customers Count By Region的存储过程。该存储过程返回顾客所在"WA"区域的数量。ALTER PROCEDURE [dbo].[NonRowse...原创 2009-06-10 16:51:27 · 96 阅读 · 0 评论 -
LINQ to SQL语句(21)之用户定义函数
用户定义函数我们可以在LINQ to SQL中使用用户定义函数。只要把用户定义函数拖到O/R设计器中,LINQ to SQL自动使用FunctionAttribute属性和ParameterAttribute属性(如果需要)将其函数指定为方法。这时,我们只需简单调用即可。在这里注意:使用用户定义函数的时候必须满足以下形式之一,否则会出现InvalidOperationException...原创 2009-06-10 16:52:39 · 88 阅读 · 0 评论 -
LINQ to SQL语句(22)之DataContext
DataContextDataContext作为LINQ to SQL框架的主入口点,为我们提供了一些方法和属性,本文用几个例子说明DataContext几个典型的应用。创建和删除数据库CreateDatabase方法用于在服务器上创建数据库。DeleteDatabase方法用于删除由DataContext连接字符串标识的数据库。数据库的名称有以下方法来定义:如果数据库在连...原创 2009-06-10 16:54:05 · 97 阅读 · 0 评论 -
LINQ to SQL语句(23)之动态查询
动态查询有这样一个场景:应用程序可能会提供一个用户界面,用户可以使用该用户界面指定一个或多个谓词来筛选数据。这种情况在编译时不知道查询的细节,动态查询将十分有用。在LINQ中,Lambda表达式是许多标准查询运算符的基础,编译器创建lambda表达式以捕获基础查询方法(例如 Where、Select、Order By、Take While 以及其他方法)中定义的计算。表达式目录树用...原创 2009-06-10 16:55:16 · 109 阅读 · 0 评论 -
LINQ to SQL语句(25)之继承
继承支持LINQ to SQL 支持单表映射,其整个继承层次结构存储在单个数据库表中。该表包含整个层次结构的所有可能数据列的平展联合。(联合是将两个表组合成一个表的结果,组合后的表包含任一原始表中存在的行。)每行中不适用于该行所表示的实例类型的列为 null。单表映射策略是最简单的继承表示形式,为许多不同类别的查询提供了良好的性能特征,如果我们要在 LINQ to SQL 中实现这种映...原创 2009-06-10 16:57:07 · 163 阅读 · 0 评论 -
LINQ to SQL语句(14)之Null语义和DateTime
Null语义说明:下面第一个例子说明查询ReportsToEmployee为null的雇员。第二个例子使用Nullable<T>.HasValue查询雇员,其结果与第一个例子相同。在第三个例子中,使用Nullable<T>.Value来返回ReportsToEmployee不为null的雇员的ReportsTo的值。1.Null查找不隶属于另一个雇员的所有雇...原创 2009-06-10 16:46:03 · 112 阅读 · 0 评论 -
LINQ to SQL语句(13)之开放式并发控制和事务
Simultaneous Changes开放式并发控制下表介绍 LINQ to SQL 文档中涉及开放式并发的术语:术语说明并发两个或更多用户同时尝试更新同一数据库行的情形。并发冲突两个或更多用户同时尝试向一行的一列或多列提交冲突值的情形。并发控制用于解决并发冲突的技术。开放式并发控制先调查其他事务是否已更改了行中的值,再允许提...原创 2009-06-10 16:45:26 · 94 阅读 · 0 评论 -
LINQ to SQL语句(12)之Delete和使用Attach
删除(Delete)1.简单形式说明:调用DeleteOnSubmit方法即可。OrderDetail orderDetail = db.OrderDetails.First (c => c.OrderID == 10255 && c.ProductID == 36);db.OrderDetails.DeleteOnSubmit(ord...原创 2009-06-10 16:44:30 · 94 阅读 · 0 评论 -
LINQ to SQL语句(2)之Select/Distinct
Select/Distinct操作符适用场景:o(∩_∩)o… 查询呗。说明:和SQL命令中的select作用相似但位置不同,查询表达式中的select及所接子句是放在表达式最后并把子句中的变量也就是结果返回回来;延迟。Select/Distinct操作包括9种形式,分别为简单用法、匿名类型形式、条件形式、指定类型形式、筛选形式、整形类型形式、嵌套类型形式、本地方法调用形式、D...原创 2009-06-10 16:23:00 · 141 阅读 · 0 评论 -
LINQ to SQL语句(3)之Count/Sum/Min/Max/Avg
Count/Sum/Min/Max/Avg操作符适用场景:统计数据吧,比如统计一些数据的个数,求和,最小值,最大值,平均数。Count说明:返回集合中的元素个数,返回INT类型;不延迟。生成SQL语句为:SELECT COUNT(*) FROM1.简单形式:得到数据库中客户的数量:var q = db.Customers.Count();2.带条件形式:...原创 2009-06-10 16:30:55 · 83 阅读 · 0 评论 -
LINQ to SQL语句(4)之Join
Join操作符适用场景:在我们表关系中有一对一关系,一对多关系,多对多关系等。对各个表之间的关系,就用这些实现对多个表的操作。说明:在Join操作中,分别为Join(Join查询), SelectMany(Select一对多选择)和GroupJoin(分组Join查询)。该扩展方法对两个序列中键匹配的元素进行inner join操作SelectMany说明:我们在写查询语句...原创 2009-06-10 16:35:28 · 103 阅读 · 0 评论 -
LINQ to SQL语句(5)之Order By
Order By操作适用场景:对查询出的语句进行排序,比如按时间排序等等。说明:按指定表达式对集合排序;延迟,:按指定表达式对集合排序;延迟,默认是升序,加上descending表示降序,对应的扩展方法是OrderBy和OrderByDescending1.简单形式这个例子使用 orderby 按雇用日期对雇员进行排序:var q = from e in d...原创 2009-06-10 16:36:52 · 172 阅读 · 0 评论 -
LINQ to SQL语句(6)之Group By/Having
Group By/Having操作符适用场景:分组数据,为我们查找数据缩小范围。说明:分配并返回对传入参数进行分组操作后的可枚举对象。分组;延迟1.简单形式:var q = from p in db.Products group p by p.CategoryID into g select g;语句描述:使用Group By按Catego...原创 2009-06-10 16:38:17 · 133 阅读 · 0 评论 -
LINQ to SQL语句(7)之Exists/In/Any/All/Contains
Exists/In/Any/All/Contains操作符适用场景:用于判断集合中元素,进一步缩小范围。Any说明:用于判断集合中是否有元素满足某一条件;不延迟。(若条件为空,则集合只要不为空就返回True,否则为False)。有2种形式,分别为简单形式和带条件形式。1.简单形式:仅返回没有订单的客户:var q = from c in db.Custom...原创 2009-06-10 16:39:30 · 89 阅读 · 0 评论 -
LINQ to SQL语句(8)之Concat/Union/Intersect/Except
Concat/Union/Intersect/Except操作适用场景:对两个集合的处理,例如追加、合并、取相同项、相交项等等。Concat(连接)说明:连接不同的集合,不会自动过滤相同项;延迟。1.简单形式:var q = ( from c in db.Customers select c.Phone )....原创 2009-06-10 16:41:09 · 57 阅读 · 0 评论 -
LINQ to SQL语句(9)之Top/Bottom和Paging和SqlMethods
Top/Bottom操作适用场景:适量的取出自己想要的数据,不是全部取出,这样性能有所加强。Take说明:获取集合的前n个元素;延迟。即只返回限定数量的结果集。var q = ( from e in db.Employees orderby e.HireDate select e) .Take(5);语句描述:选择所雇用的前5个雇员。...原创 2009-06-10 16:42:10 · 83 阅读 · 0 评论 -
LINQ to SQL语句(10)之Insert
插入(Insert)1.简单形式说明:new一个对象,使用InsertOnSubmit方法将其加入到对应的集合中,使用SubmitChanges()提交到数据库。NorthwindDataContext db = new NorthwindDataContext();var newCustomer = new Customer{ CustomerID = "MCS...原创 2009-06-10 16:42:53 · 76 阅读 · 0 评论 -
LINQ to SQL语句(11)之Update
更新(Update)说明:更新操作,先获取对象,进行修改操作之后,直接调用SubmitChanges()方法即可提交。注意,这里是在同一个DataContext中,对于不同的DataContex看下面的讲解。1.简单形式Customer cust = db.Customers.First(c => c.CustomerID == "ALFKI");cust.Co...原创 2009-06-10 16:43:26 · 109 阅读 · 0 评论 -
LINQ简介
查询表达式(LINQ)简介在上两篇我介绍了C#3.0新语特性和改进,这些新特性在我们编写程序时为我们提供了非常大的帮助。从这篇开始,我们开始一起来探讨LINQ。LINQ是Language Integrated Query的简称,它是集成在.NET编程语言中的一种特性。已成为编程语言的一个组成部分,在编写程序时可以得到很好的编译时语法检查,丰富的元数据,智能感知、静态类型等强类型语言...原创 2009-06-10 16:58:15 · 222 阅读 · 0 评论