LINQ体验(13)——LINQ to SQL语句之运算符转换和ADO.NET与LINQ to SQL
运算符转换
1.AsEnumerable:将类型转换为泛型 IEnumerable
使用 AsEnumerable<TSource> 可返回类型化为泛型 IEnumerable 的參数。在此演示样例中,LINQ to SQL(使用默认泛型 Query)会尝试将查询转换为 SQL 并在server上运行。
但 where 子句引用用户定义的client方法 (isValidProduct),此方法无法转换为 SQL。
解决方法是指定 where 的client泛型 IEnumerable<T> 实现以替换泛型 IQueryable<T>。可通过调用 AsEnumerable<TSource>运算符来运行此操作。
- var q =
- from p in db.Products.AsEnumerable()
- where isValidProduct(p)
- select p;
语句描写叙述:这个样例就是使用AsEnumerable以便使用Where的clientIEnumerable实现,而不是默认的IQueryable将在server上转换为SQL并运行的默认Query<T>实现。这非常有必要,由于Where子句引用了用户定义的client方法isValidProduct,该方法不能转换为SQL。
2.ToArray:将序列转换为数组
使用 ToArray <TSource>可从序列创建数组。
- var q =
- from c in db.Customers
- where c.City == "London"
- select c;
- Customer[] qArray = q.ToArray();
语句描写叙述:这个样例使用 ToArray 将查询直接计算为数组。
3.ToList:将序列转换为泛型列表
使用 ToList<TSource>可从序列创建泛型列表。以下的演示样例使用 ToList<TSource>直接将查询的计算结果放入泛型 List<T>。
- var q =
- from e in db.Employees
- where e.HireDate >= new DateTime(1994, 1, 1)
- select e;
- List<Employee> qList = q.ToList();
4.ToDictionary:将序列转化为字典
使用Enumerable.ToDictionary<TSource, TKey>方法能够将序列转化为字典。TSource表示source中的元素的类型;TKey表示keySelector返回的键的类型。其返回一个包括键和值的Dictionary<TKey, TValue>。
- var q =
- from p in db.Products
- where p.UnitsInStock <= p.ReorderLevel && !p.Discontinued
- select p;
- Dictionary<int, Product> qDictionary =
- q.ToDictionary(p => p.ProductID);
- foreach (int key in qDictionary.Keys)
- {
- Console.WriteLine(key);
- }
语句描写叙述:这个样例使用 ToDictionary 将查询和键表达式直接键表达式直接计算为 Dictionary<K, T>。
ADO.NET与LINQ to SQL
LINQ to SQL 基于由 ADO.NET 提供程序模型提供的服务。因此,我们能够将 LINQ to SQL 代码与现有的 ADO.NET 应用程序混合在一起,将当前 ADO.NET 解决方式迁移到 LINQ to SQL。
1.连接
在创建 LINQ to SQL DataContext 时,能够提供现有 ADO.NET 连接。对 DataContext 的全部操作(包含查询)都使用所提供的这个连接。
假设此连接已经打开,则在您使用完此连接时,LINQ to SQL 会保持它的打开状态不变。我们始终能够訪问此连接。另外还能够使用 Connection 属性自行关闭它。
- //新建一个标准的ADO.NET连接:
- SqlConnection nwindConn = new SqlConnection(connString);
- nwindConn.Open();
- // ... 其他的ADO.NET数据操作代码... //
- //利用现有的ADO.NET连接来创建一个DataContext:
- Northwind interop_db = new Northwind(nwindConn);
- var orders =
- from o in interop_db.Orders
- where o.Freight > 500.00M
- select o;
- //返回Freight>500.00M的订单
- nwindConn.Close();
语句描写叙述:这个样例使用预先存在的ADO.NET连接创建Northwind对象。本例中的查询返回运费至少为500.00 的全部订单。
2.事务
当我们已经启动了自己的数据库事务而且我们希望DataContext 包括在内时。我们能够向 DataContext 提供此事务。
通过 .NET Framework 创建事务的首选方法是使用 TransactionScope 对象。通过使用此方法,我们能够创建跨数据库及其它驻留在内存中的资源管理器运行的分布式事务。
事务范围差点儿不须要资源就能够启动。它们仅在事务范围内存在多个连接时才将自身提升为分布式事务。
- using (TransactionScope ts = new TransactionScope())
- {
- db.SubmitChanges();
- ts.Complete();
- }
注意:不能将此方法用于全部数据库。
比如。SqlClient 连接在针对 SQL Server 2000 server使用时无法提升系统事务。它採取的方法是。仅仅要它发现有使用事务范围的情况,它就会自己主动向完整的分布式事务登记。
以下用一个样例说明一下事务的用法。在这里。也说明了重用 ADO.NET 命令和 DataContext 之间的同一连接。
- var q =
- from p in db.Products
- where p.ProductID == 3
- select p;
- //使用LINQ to SQL查询出来
- //新建一个标准的ADO.NET连接:
- SqlConnection nwindConn = new SqlConnection(connString);
- nwindConn.Open();
- //利用现有的ADO.NET连接来创建一个DataContext:
- Northwind interop_db = new Northwind(nwindConn);
- SqlTransaction nwindTxn = nwindConn.BeginTransaction();
- try
- {
- SqlCommand cmd = new SqlCommand("UPDATE Products SET"
- +"QuantityPerUnit = 'single item' WHERE ProductID = 3");
- cmd.Connection = nwindConn;
- cmd.Transaction = nwindTxn;
- cmd.ExecuteNonQuery();
- interop_db.Transaction = nwindTxn;
- Product prod1 = interop_db.Products.First(p => p.ProductID == 4);
- Product prod2 = interop_db.Products.First(p => p.ProductID == 5);
- prod1.UnitsInStock -= 3;
- prod2.UnitsInStock -= 5;//这有一个错误,不能为负数
- interop_db.SubmitChanges();
- nwindTxn.Commit();
- }
- catch (Exception e)
- {
- //假设有一个错误。全部的操作回滚
- Console.WriteLine(e.Message);
- }
- nwindConn.Close();
语句描写叙述:这个样例使用预先存在的 ADO.NET 连接创建 Northwind 对象,然后与此对象共享一个 ADO.NET 事务。此事务既用于通过 ADO.NET 连接运行 SQL 命令。又用于通过 Northwind 对象提交更改。当事务因违反 CHECK 约束而中止时。将回滚全部更改。包含通过 SqlCommand 做出的更改。以及通过Northwind 对象做出的更改。
3.直接运行 SQL语句
1.直接运行SQL查询
假设 LINQ to SQL 查询不足以满足专门任务的须要,我们能够使用 ExecuteQuery 方法来运行 SQL 查询,然后将查询的结果直接转换成对象。
- var products = db.ExecuteQuery<Product>(
- "SELECT [Product List].ProductID,"+
- "[Product List].ProductName " +
- "FROM Products AS [Product List] " +
- "WHERE [Product List].Discontinued = 0 " +
- "ORDER BY [Product List].ProductName;"
- );
语句描写叙述:这个样例使用ExecuteQuery<T>运行随意 SQL 查询,并将所得的行映射为 Product 对象的序列。
2.直接运行SQL命令
採用DataContext 连接时,能够使用ExecuteCommand来运行不返回对象的 SQL 命令。
- db.ExecuteCommand
- ("UPDATE Products SET UnitPrice = UnitPrice + 1.00");
LINQ体验(13)——LINQ to SQL语句之运算符转换和ADO.NET与LINQ to SQL的更多相关文章
- sql 语句使用和转换json数据
1 连接mysql import pymysql import concurrent coon=pymysql.connect(host='localhost',user='root',passwor ...
- SQL语句报错:You have an error in your SQL syntax; check the manual that corresponds to your MariaDB server version for the right syntax to use near
报错如图: 最开始其实我的列名tname和tsubject分别叫name和subject,后来看到网上有说这个报错可能是数据库建表的时候使用了mysql的关键词,我就只把name改了.后来还是这个问题 ...
- sql语句 异常 Err] 1064 - You have an error in your SQL syntax;
在我们开发的工程中,有时候会报[Err] 1064 - You have an error in your SQL syntax; check the manual that corresponds ...
- SqlServer和Oracle中一些常用的sql语句3 行列转换
--217, SQL SERVER SELECT Cust_Name , MAX(CASE WHEN Order_Date ='2009-08-01' THEN AR END) "2009- ...
- 简述项目中优化sql语句执行效率的方法,从哪些方面,sql语句性能如何分析?
(1)尽量选择较小的列: (2)将where中用的比较频繁的字段建立索引: (3)select中避免使用*: (4)避免在索引列上使用计算.not in和<>等操作: (5)当只需要一行数 ...
- Sql语句groupBY分组后取最新一条记录的SQL
一.问题 groupBY分组后取最新一条记录的SQL的解决方案. 二.解决方案 select Message,EventTime from PT_ChildSysAlarms as a where E ...
- SQL语句的行列转换
[一]行转列 1,查询原始的数据 /***这次练习的主题,行转列,列转行***/select * from Scores 2,得到姓名,通过group by select Student as '姓名 ...
- LINQ to SQL语句非常详细(原文来自于网络)
LINQ to SQL语句(1)之Where Where操作 适用场景:实现过滤,查询等功能. 说明:与SQL命令中的Where作用相似,都是起到范围限定也就是过滤作用的,而判断条件就是它后面所接的子 ...
- LINQ to SQL语句
http://kb.cnblogs.com/page/42477/2/ 本系列文章导航 LINQ to SQL语句(1)之Where LINQ to SQL语句(2)之Select/Distinct ...
随机推荐
- 用asp.net+Jquery+Ajax+sqlserver编写的 (英语六级记单词)
开始(英语对程序员的重要性引用) 出处 英语的重要性已经毋庸置疑,对于程序员来说更甚,一些最新的技术资料是英文的,如果想进入外企英语也是一个很重要的条件.对于程序员来说怎样学习好英语,在此谈一下我的一 ...
- 用上GIT你一定会爱上他
前言 Git是一个开源的分布式版本控制系统,用以有效.高速的处理从很小到非常大的项目版本管理. Git 是 Linus Torvalds 为了帮助管理 Linux 内核开发而开发的一个开放源码的版本控 ...
- ogre3D程序实例解析1-平移旋转与缩放
接着上篇写 http://www.cnblogs.com/songliquan/p/3294902.html 旋转 这里有必要看一下关于旋转的源代码: virtual void pitch(co ...
- Django数据库的查看、删除,创建多张表并建立表之间关系
配置以下两处,可以方便我们直接右键运行tests.py一个文件,实现对数据库操作语句的调试: settings里面的设置: #可以将Django对数据库的操作语法,能输出对应的的sql语句 LOGGI ...
- Thinkphp5.1手册太简单,有的功能用起来不确定结果是否和预料的一样,顾整理记录
//模板{if false} 1 {else/} //====>可以使用 效果同 {else /} 2 {/if} {if condition="(1 eq 1) and false& ...
- iOS学习笔记25-录音和网络流媒体
.录音 AVFoundation框架还有一个AVAudioRecorder类专门处理录音操作,它同样支持多种音频格式. 先来了解下AVAudioRecorder的常用属性: @property (re ...
- BZOJ3993 [SDOI2015]星际战争 【二分 + 网络流】
题目 3333年,在银河系的某星球上,X军团和Y军团正在激烈地作战.在战斗的某一阶段,Y军团一共派遣了N个巨型机器人进攻X军团的阵地,其中第i个巨型机器人的装甲值为Ai.当一个巨型机器人的装甲值减少到 ...
- linux下定时任务设置
原文http://www.blogjava.net/freeman1984/archive/2010/09/23/332715.html 觉这篇文章写的挺全的,把它拿过来存在博客里,方便以后查询. 为 ...
- spring-boot项目MapperScan注解包含多个包
单个包 @MapperScan("com.mysiteforme.admin.dao") 多个包 @MapperScan({"com.mysiteforme.admin. ...
- TSP 旅行商问题(状态压缩dp)
题意:有n个城市,有p条单向路径,连通n个城市,旅行商从0城市开始旅行,那么旅行完所有城市再次回到城市0至少需要旅行多长的路程. 思路:n较小的情况下可以使用状态压缩dp,设集合S代表还未经过的城市的 ...