什么是泛用LINQ 语句
泛用LINQ语句的概念很简单,在一些情况下,我们会有需求使用同一段程式码来对不同资料表做查询,这在ADO.NET中很容易达到,见下例:
| 以下为引用的内容: static void PrintCustomerID(SqlDataReader reader) { Console.WriteLine(reader.GetString(reader.GetOrdinal("CustomerID"))); } |
此函式接受一个Reader物件,然后顷印CustomerID栏位值,这不受限于SqlDataReader所选取的Schema或是资料表,只要Schema中有CustomerID栏位即可。
不过,这样的手法在LINQ这种Typed-Query(具型别查询语句)模式下,并没有很直觉的写法,因为你不能写下下面的句子。
| 以下为引用的内容: static void Test2(int index) { var query; DataClasses1DataContext context = new DataClasses1DataContext(); context.Log = Console.Out; //for log only,you can remove it. if (index == 1) query = context.Customers; else query = context.Orders; var result = from s1 in query where s1.CustomerID.Contains("V") select s1; foreach (var item in result) { Console.WriteLine(item.CustomerID); } } |
编译器会抱怨,var的变数必须在宣告时指定。那要如何在LINQ To SQL或是LINQ To Entites达到同样的效果呢?这有几个方法可以做到。
1、使用ExecuteQuery,并使用另一个Typed物件来接收回传集。
2、使用实体类别(Entity Class)继承。
3、使用Cast与partial class。
1与2对熟悉LINQ To SQL的读者应该不难,所以我就不再赘述了,第三个手法是较少见的,我们可以运用partial class机制,让Entity Classes实作特定介面,然后以Cast函式来达到目的。
| 以下为引用的内容: using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Data.Linq; using System.Data.SqlClient; namespace ConsoleApplication39 { class Program { static void Main(string[] args) { Test(1); Console.WriteLine("------"); Test(0); Console.ReadLine(); } static void Test(int index) { IQueryable<IGenericBaseClass> query = null; DataClasses1DataContext context = new DataClasses1DataContext(); context.Log = Console.Out; //for log only,you can remove it. if(index == 1) query = context.Customers.Cast<IGenericBaseClass>(); else query = context.Orders.Cast<IGenericBaseClass>(); var result = from s1 in query where s1.CustomerID.Contains("V") select s1; foreach (var item in result) { Console.WriteLine(item.CustomerID); } } } public interface IGenericBaseClass { string CustomerID { get; set; } } partial class Customers : IGenericBaseClass { } partial class Orders : IGenericBaseClass { } } |
仔细揣摩上面的代码,我相信你会找到一个不一样的LINQ应用手法。
| · 网络函数库 | |
| · SQL Server不存在或访问被拒绝 Window | |
| · ASP.NET中动态控制RDLC报表 | |
| · 用PHP发送MIME邮件(五) | |
| · 在asp.net中为Web用户控件添加属性和事 | |
| · ASP检索网站指定目录文件的算法与应用 | |
| · 用PHP发送MIME邮件(四) | |
| · FrontPage服务器扩展 | |
| · 用ASP建立站内搜索 | |
| · 数据仓库解决方案指南 |
| · ASP动态网页编程的19个基本技巧 | |
| · 其它的ASP常用组件 | |
| · 抓取和分析 | |
| · ADO 存取数据库时如何分页显示 | |
| · 关于使用文本域(TextArea)的一个问题 | |
| · 堵住ASP漏洞 | |
| · PHP的面向对象编程:开发大型PHP项目 | |
| · 最新的ASP、IIS安全漏洞 | |
| · PHP的面向对象编程:开发大型PHP项目 | |
| · IIS 的 概 念 |