0

0

使用LinQ实现对数据对象的查询

php中文网

php中文网

发布时间:2016-06-07 16:11:04

|

2606人浏览过

|

来源于php中文网

原创

因为项目需要,接触到了LinQ,经过一段时间的学习,对LinQ有了简单的认识,本文就这个话题做个简单的叙述。 首先,应该写出几个问题,从宏观上了解一下。LinQ是什么?为什么使用LinQ?使用它有什么好处? 语言集成查询(Language Intergrated Query),是一

因为项目需要,接触到了linq,经过一段时间的学习,对linq有了简单的认识,本文就这个话题做个简单的叙述。

首先,应该写出几个问题,从宏观上了解一下。LinQ是什么?为什么使用LinQ?使用它有什么好处?

语言集成查询(Language Intergrated Query),是一组用于C#和vb语言的扩展,它允许编写C#或者vb代码以查询数据库相同的方式操作内存数据。----百度百科

通俗点说,它就是查询数据的。那么为什么要用它来查询数据呢,使用它有什么有点吗?

我们从稍微抽象一点的角度来考虑这个问题。面向对象的编程和数据访问的割裂:一 面向对象的语言和数据库有两套完全不相干的数据类型体系,编程语言中的string,在数据库中就是varchar,这完全没有统一性可言;二 SQL编码体验落后,我们编写SQL的语句,没有提示语句,只有写完了,才知道是否正确,客户体验度差;三 各类查询语言不一致,XML和数据库都有各自的数据查询体系,对象没有自己的查询体系。基于以上种种问题,LinQ出现了。

组成 上面也提到了,LinQ包括三类内容的查询,对象,XML文件和数据库。对数据库的查询分为三个部分:

Linq to sql,

linq to DataSet,

linq to Entities。

\

喎?http://www.2cto.com/kf/ware/vc/" target="_blank" class="keylink">vcD4KPHA+ICAgICAgICCy6dGvt73KvaO6TGluUbLp0a/K/b7d09DBvdbWt73KvaOs0+/R1LLp0a+6zbe9t6iy6dGvCqGjsunRr9PvvuTKtdPDwOAmIzIwMjg0O9PaU1FM0+++5LXE0M7KvbLp0a+jrNXi1ta3vcq9v8m2wdDUx78Ko6y1q8rHz97Wxr3PtuCjrLbU09q24Mz1vP6y6dGvutzE0cq1z9aho7Lp0a+3vbeot73KvaO61eLW1re9yr2/ybbB0NSyu8e/o6y1q8rHv8nS1Mq1z9a63LbguLTU07XEsunRr9Kqx/OjrNLyzqrO0sPHv8nS1L2rsunRr8z1vP61pbbA1/bSu7j2t723qMilyrXP1qGjzaizo8fpv/ajrM6qwcu0+sLrtcS/ybbB0NSjrM7Sw8fK18/I06a4w7+8wsfKudPDsunRr9Pv0dS3vcq9o6zI57n7sunRr9Pv0dTE0dLUyrXP1qOs06a4w72rsunRr9Pv0dS6zbLp0a+3vbeoveG6z8bwwLS77LHgyrnTw6Os1eLR+bzI1+6087uvtcTKtc/Wwcu0+sLrv8m2wdDUo6zSstT2x7/By7Lp0a+5psTcoaM8L3A+CjxwPiBsaW5xtcS8uNbWuN+8trLp0a+3vbeoo7o8L3A+CjxwPr7bus+juk1heCxNaW4sQ291bnQsU3VttcijuzwvcD4KPHA+xcXQ8qO6VGhlbkJ5LE9yZGVyQnm1yKO7PC9wPgo8cD631sf4o7pUYWtlLFNraXAsVGFrZVdoaWxlLFNraXBXaGlsZbXIo7s8L3A+CjxwPryvus+jukRpc3RpbmN0PC9wPgo8cD7J+rPJo7pSYW5nZSxSZXBlYXQ8L3A+CjxwIGxhbmc9"en-US">

下面是几个LinQ查询示例:

1 基于语言、方法混编查询的方式(linq to objects):

private void btnQuery_Click(object sender, EventArgs e)
        {
            //LinQ To Object 基本方法部分
            //泛型集合数据 person
            List person = new List();
            person.Add("老 大");
            person.Add("老 二");
            person.Add("老 三");
            person.Add("老 四");
            person.Add("老 五");
            person.Add("小 六");
            person.Add("小 七");
            person.Add("小 八");

            ////输出person 所有元素
            //var result = from p in person select p;

            //输出person中所有以老开头的人
            //语句、方法混编模式,使用语句查询,使用方法筛选
            var result = (from p in person select p).Where(p => p.StartsWith("老"));
            //打印
            result.Print();
        } 
public static void Print(this IEnumerable ie)
        {
            //获取可遍历的接口
            IEnumerator result = ie.GetEnumerator();
            while (result.MoveNext())
            {
                Console.WriteLine("\n------------------------\n");

                Console.WriteLine(result.Current);

                Console.WriteLine("\n------------------------\n");
            }
        } 

这段代码首先定义了一个泛型集合对象person,然后使用查询语句和查询费昂发混编模式查询出以“老”开头的人,然后打印出来。查询语句不能完成所有的查询功能,需要借助查询方法来筛选,本例中的查询方法为系统提供。可以看出来,查询语句可读性强,但是功能不够强大,查询方法可读性不强,功能比较多。

	2 基于查询方法模式(linq to objects)
	private void btnSelect_Click(object sender, EventArgs e)
	        {
	            //LinQ To Object 基本方法部分
	            //泛型集合数据 person
	            List person = new List();
	            person.Add("老 大");
	            person.Add("老 二");
	            person.Add("老 三");
	            person.Add("老 四");
	            person.Add("老 五");
	            person.Add("小 六");
	            person.Add("小 七");
	            person.Add("小 八");
		    //方法四 调用外部复杂方法作为查询条件
	           var result = person.Where(p => Judge(p));
		}
	public bool Judge(String s)
	        {
	            if (s.StartsWith("老"))
	            {
	                return true;
	            }
	            else
	            {
	                return false;
	            }
	        } 
本段代码功能同上,完全使用查询方法完成了筛选功能,这个方法不同于上例中的方法,此方法是重新定义的方法。
	3 基于数据库的查询(LinQ to Entities)
	public ActionResult Index()
	        {
			//1 使用linq语句获取实体数据
			//查询条件中使用了lambda表达式
			List list = (from b in db.BlogArticle where b.AIsDel ==false select b).ToList ();
			//2 使用viewdata获取数据
		       ViewData["DataList"] = list;
		
		       // 3 加载视图
		       list.Print();
		} 
	 public partial class BlogArticle
	    {
			实体代码:略
	     }
        

成新网络商城购物系统
成新网络商城购物系统

使用模板与程序分离的方式构建,依靠专门设计的数据库操作类实现数据库存取,具有专有错误处理模块,通过 Email 实时报告数据库错误,除具有满足购物需要的全部功能外,成新商城购物系统还对购物系统体系做了丰富的扩展,全新设计的搜索功能,自定义成新商城购物系统代码功能代码已经全面优化,杜绝SQL注入漏洞前台测试用户名:admin密码:admin888后台管理员名:admin密码:admin888

下载

本例中,我们只是将数据对象替换成了实体集合,基本语法相同。

优点:书写简单,容易上手。以对象的形式查询数据,配合查询语句和查询方法的使用,是数据查询更加直观。

缺点:linq使用延迟加载功能,将待操作数据放入内存中,占用了大量资源,造成资源浪费。


热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
C++ 设计模式与软件架构
C++ 设计模式与软件架构

本专题深入讲解 C++ 中的常见设计模式与架构优化,包括单例模式、工厂模式、观察者模式、策略模式、命令模式等,结合实际案例展示如何在 C++ 项目中应用这些模式提升代码可维护性与扩展性。通过案例分析,帮助开发者掌握 如何运用设计模式构建高质量的软件架构,提升系统的灵活性与可扩展性。

14

2026.01.30

c++ 字符串格式化
c++ 字符串格式化

本专题整合了c++字符串格式化用法、输出技巧、实践等等内容,阅读专题下面的文章了解更多详细内容。

9

2026.01.30

java 字符串格式化
java 字符串格式化

本专题整合了java如何进行字符串格式化相关教程、使用解析、方法详解等等内容。阅读专题下面的文章了解更多详细教程。

12

2026.01.30

python 字符串格式化
python 字符串格式化

本专题整合了python字符串格式化教程、实践、方法、进阶等等相关内容,阅读专题下面的文章了解更多详细操作。

4

2026.01.30

java入门学习合集
java入门学习合集

本专题整合了java入门学习指南、初学者项目实战、入门到精通等等内容,阅读专题下面的文章了解更多详细学习方法。

20

2026.01.29

java配置环境变量教程合集
java配置环境变量教程合集

本专题整合了java配置环境变量设置、步骤、安装jdk、避免冲突等等相关内容,阅读专题下面的文章了解更多详细操作。

18

2026.01.29

java成品学习网站推荐大全
java成品学习网站推荐大全

本专题整合了java成品网站、在线成品网站源码、源码入口等等相关内容,阅读专题下面的文章了解更多详细推荐内容。

19

2026.01.29

Java字符串处理使用教程合集
Java字符串处理使用教程合集

本专题整合了Java字符串截取、处理、使用、实战等等教程内容,阅读专题下面的文章了解详细操作教程。

3

2026.01.29

Java空对象相关教程合集
Java空对象相关教程合集

本专题整合了Java空对象相关教程,阅读专题下面的文章了解更多详细内容。

6

2026.01.29

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Node.js 教程
Node.js 教程

共57课时 | 9.8万人学习

CSS3 教程
CSS3 教程

共18课时 | 5万人学习

Git 教程
Git 教程

共21课时 | 3.1万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号