LINQ to SQL快速上手 step by step

合集下载

C#高级特性-第5章 LINQ to SQL 高级特性(理论)

C#高级特性-第5章 LINQ to SQL 高级特性(理论)
上的键值
ThisKey:strin对g类应型数,据指库示中此关实体系类的的名成称员表示关联的此端上的键值
[Association(Name="Category_Product", Storage="_Product",
ThisKey="Id", OtherKey="CategoryId")]
public EntitySet<Product> Product {
使用控制台输出来记录
仅当查询被执行时,才会将查询生成的 SQL代码输出到控制台上 。使用ToList方 法强制查询即时执行
使用日志文件记录查询生成的Sql代码
Log属性
StreamWriter sw = new StreamWriter(bine(Environment.GetFolderPath(Environm ent.SpecialFolder.Desktop), "log.txt")); PosDataContext db = new PosDataContext(); db.Log = sw; db.Product.Where(a => a.CategoryId == 1).ToList(); sw.Flush(); sw.Close();
本章内容
对象关系映射概念 Linq to Sql的属性映射方式 Linq to Sql的调试支持 Linq to Sql并发、事务、延迟加载、缓存等高级特性
理解Dbml生成的映射代码 掌握Linq to Sql的调试支持 掌握Linq to Sql的并发冲突处理 掌握Linq to Sql的事务处理、延迟加载 了解Linq to Sql的缓存特性

一步一步学Linq to sql

一步一步学Linq to sql
Console.WriteLine(ername);
意义不是很大,纯粹解决机械劳动。编译器自动为你生成get、set操作以及字段,并且你不能使用字段也不能自定义get、set操作,不过你可以分别定义get和set的访问级别。
对象初始化器
publicclassPerson
{
publicstringusername {get;set; }
Table<Customer> Customers = ctx.GetTable<Customer>();
GridView1.DataSource =fromcinCustomerswherec.CustomerID.StartsWith("A")selectnew{顾客ID=c.CustomerID,顾客名=,城市=c.City};
Console.WriteLine("username:{0} age:{1}", ername, data.age);
匿名类型允许开发人员定义行内类型,无须显式定义类型。常和var配合使用,var用于声明匿名类型。定义一个临时的匿名类型在LINQ查询句法中非常常见,我们可以很方便的实现对象的转换和投影。
今天就说到这里,再见!
DataContext与实体
DataContext
DataContext类型(数据上下文)是System.Data.Linq命名空间下的重要类型,用于把查询句法翻译成SQL语句,以及把数据从数据库返回给调用方和把实体的修改写入数据库。
DataContext提供了以下一些使用的功能:
?以日志形式记录datacontext生成的sql?执行sql包括查询和更新语句?创建和删除数据库datacontext是实体和数据库之间的桥梁那么首先我们需要定义映射到数据表的实体

第12章 LINQ to SQL数据

第12章  LINQ to SQL数据

融智技术学院
12.4.1 基本查询
1.Where语法 本章之前所有实例都采用单一条件的简单条件查询。LINQ中的 Where语句支持或者“!!”、并且“&&”的逻辑运算。 2.Select语句 Select语句就是将实体类部分(或全都)字段进行投影,并创建 另一个新数据表对象。 3.Distinct语句 Distinct语句主要用于查询显示数据对象中非重复元素。 4.First、Last、ElementAt语句 First语句用于查询数据对象中第一个对象数据,相当于SQL语 句中的TOP 1。Last语句用于查询数据对象中最后一个对象数据。 ElementAt(init i)语句用于查询数据对象中指定位置的对象数据。
融智技术学院
12.2.5 执行 执行SQL查询 查询
LINQ to SQL可以实现90%以上的SQL查询。但由于 LINQ to SQL要转换为SQL查询,才可以查询操作关系型 数据库。对于一些较为复杂数据查询,直接通过SQL查询 的效率比LINQ查询更好。因此,DataContext类型也提供 了直接执行SQL语句的功能。下面通过实例来演示 DataContext类实现直接执行SQL语句的功能。
融智技术学院
12.2.6 创建强类型 创建强类型DataContext
创建强类型DataContext,就是把实体类、DataContext 的构造函数封装为DataContext的成员与方法。经过这样的封 装后,当创建强类型DataContext的一个实例与数据库连接, 就可以自动把数据表映射连接到相应的实体类,进而可以在 程序中通过“.”直接访问实体类的属性及方法。
融智技术学院
12.2.1 搭建开发环境
前面已经说过,LINQ to SQL是一个项目组件。首 先应该将其添加为网站引用,具体操作步骤如下所示。

LINQ to SQL快速上手 step by step

LINQ to SQL快速上手 step by step

总结
希望能帮助大家快速上手Linq to Sql. 关于Linq to Sql,还有许多丰富的功能 和细节问题,篇幅原因不能详述,各位 可以参考相关资料.

Step2:建立LINQ to SQL Step2:建立LINQ Classes文件 Classes文件
数据建好后,我们需要建立LINQ to SQL Classes文件.这种文件是Linq to Sql框架的 主要文件,后面自动生成的实体类和ORM代码 都存在于这个文件中. 我们打开VS2008,新建一个C# Class Labrary 工程,名称为LinqToSqlDemo.Orm,建好后在 工程上单击右键,选择"Add"->"New Item", 在文件类型中选择"LINQ to SQL Classes", 文件名命名为"DataClasses.dbml",如图所 示
Insert操作 Insert操作 Insert用于向数据库添加记录.一 般情况下,使用"DataContext.表映射 集合.InsertOnSubmit(实体类)"的方式 就可以完成Insert操作.不过这里要注 意一点,由于Linq to Sql使用了"Unit of Work"模式,所以,对数据库的操作 不会mitChanges方法,所 有改动才会被提交到数据库.
Delete操作 Delete操作 Delete操作用于从数据库中删除记 录.表映射集合的DeleteOnSubmit方法 可以实现这个操作.这个方法需要一个 参数,就是要删除的实体类,这里不能 直接传个ID去删除,要首先通过ID找到 相应实体类,传给DeleteOnSubmit再删 除.当然最后不要忘了SubmitChanges.

linq转化为sql语句的方法

linq转化为sql语句的方法

linq转化为sql语句的方法Linq转化为SQL语句的方法概述Linq(Language Integrated Query)是微软推出的一种用于查询和操作数据的统一编程模型。

它可以在不同的数据源上执行查询,例如关系型数据库、XML文档等。

在开发过程中,我们常常需要将Linq 表达式转化为相应的SQL语句,以便对数据库进行操作。

本文将详细介绍多种将Linq转化为SQL语句的方法。

1. LINQ to SQL基本概念LINQ to SQL是一种将LINQ查询转化为SQL语句的方法。

它是Entity Framework的一部分,提供了一种直接在.NET应用程序中使用对象来表示和操作关系型数据库的方式。

在LINQ to SQL中,可以通过DataContext对象来执行查询,并将查询结果转化为SQL语句。

示例代码using System;using ;using ;public class Program{public static void Main(){// 创建DataContext对象,连接数据库DataContext context = new DataContext("Data Sour ce=.;Initial Catalog=MyDatabase;Integrated Security=True ");// 创建查询表达式var query = from c in <Customer>()where == "Beijing"select c;// 执行查询并获取SQL语句string sql = (query).CommandText;// 输出SQL语句(sql);}}2. Entity Framework基本概念Entity Framework是微软推出的一种对象关系映射(ORM)工具,可以映射.NET对象与数据库中的表、视图等关系。

LINQ to SQL

LINQ to SQL

LINQ查询的目的是从指定的数据源中查询满足符合特定条件的数据元素,并且通过根据需要对这些查询的元素进行排序、连接等操作。

所以LINQ查询包含如下几个主要元素:•数据源:数据源表示LINQ查询将从哪里查找数据,它通常是一个或多个数据集,每个数据集包含一系列的元素。

数据集是一个类型为IEnumerable<T>或IQueryable<T>的对象,可以对它进行枚举,遍历每一个元素。

此外,它的元素可以是任何数据类型,所以可以表示任何数据的集合。

•目标数据:数据源中的元素并不定是查询所需要的结果。

目标数据用来指定查询的具体想要的是什么数据。

在LINQ中,它定义了查询结果数据集中元素的具体类型。

•筛选条件:筛选条件定义了对数据源中元素的过滤条件。

只有满足条件的元素才作为查询结果返回。

筛选条件可以是简单的逻辑表达式表示,也可以用具有复杂逻辑的函数来表示。

•附加操作:附加操作表示一些其它的具体操作。

比如,对查询结果进行分组等。

其中,数据源和目标数据库是LINQ查询的必备元素,筛选条件和附加操作是可选元素。

2.用from子句指定数据源每个LINQ查询都以from子句开始,from子句包括以下两个功能。

•指定查询将采用数据源。

•定义一个本地变量,表示数据源中单个元素。

单个from子句的编写格式如下所示。

其中dataSource表示数据源,localVar 表示单个元素。

from localVar in dataSource3.用select子句指定目标数据select子句指定在执行查询时产生结果的数据集中元素的类型,它的格式如下所示:select element4.用where子句指定筛选条件在LINQ中,用where子句指定查询的过滤条件,它的格式如下:where expression其中,express是一个逻辑表达式,返回布尔值“真”或“假”在LINQ查询中,还可以使用多个并列的where子句来进行多个条件过滤。

第十六章 LINQ to SQL

第十六章 LINQ to SQL

1-11
1-3
LINQ to SQL和
LINQ
LINQ查询基础 LINQ对象模型
LINQ to SQL 支持程序

DataSet/DataTable DataAdapter DataCommand DataConnection 数据库提供程序
多种类型数据库 SQL Server、Oracle、Access等
1-10
修改数据库记录
DataContext类作为对象模型和数据库模型之间的桥梁,在 提供读取数据库接口的同时还提供了数据库修改接口。通过 DataContext类修改数据通常包含以下4个步骤: • (1)创建对象关系模型,创建和数据库对应的 DataContext类型。 • (2)通过DataContext类提供的数据表对象获取数据记录 • (3)通过设置类的属性来修改记录的值。 • (4)通过DataContext类的SubmitChanges()方法将修 改后的数据提交到数据库。 例:将所有默认密码666666改为ABCDEF
1-5
LINQ to SQL查询执行流程
应用程序
LINQ to SQL
DataAdapter DataCommand DataConnection
数据库
LINQ 查询
SQL命令
查询结果
对象集合
DataSet DataReader
1-6
O/R设计器
Visual Studio 2010为开发人员提供了一套自动化的对象关系 设计器——O/R设计器。O/R设计器提供一个可视化设计界面, 通过向导自动创建基于数据库中对象的LINQ to SQL实体类和 关系,并且可以像编辑类图和数据库关系图那样编辑各个类、 成员等。 O/R设计器还提供了相关功能,用于将存储过程和函数映射到 DataContext方法以便返回数据和填充实体类。最后, O/R 设 计器提供了对实体类之间的继承关系进行设计的能力。 例:使用O/R设计器。

LINQ体验(9)——LINQ_to_SQL语句之Insert、Update、Delete操作

LINQ体验(9)——LINQ_to_SQL语句之Insert、Update、Delete操作
c1 = tempdb.Customers.Single(c => c.CustomerID == "ALFKI"); deserializedC1 = new Customer {
Address = c1.Address, City = c1.City, CompanyName = panyName, ContactName = c1.ContactName, ContactTitle = c1.ContactTitle, Country = c1.Country, CustomerID = c1.CustomerID, Fax = c1.Fax, Phone = c1.Phone, PostalCode = c1.PostalCode, Region = c1.Region }; Customer tempcust = tempdb.Customers.Single(c => c.CustomerID == "ANTON"); foreach (Order o in tempcust.Orders) { deserializedOrders.Add(new Order {
foreach (var p in q) {
p.UnitPrice += 1.00M; } db.SubmitChanges();
Delete
1.简单形式
说明:调用 DeleteOnSubmit 方法即可。
OrderDetail orderDetail = db.OrderDetails.First (c => c.OrderID == 10255 && c.ProductID == 36);
Order order = db.Orders.First(x => x.OrderID == 10248); OrderDetail od =

目前本人收集的最全的LINQ入门资料大家一起LINQ吧

目前本人收集的最全的LINQ入门资料大家一起LINQ吧

目前本人收集的最全的LINQ入门资料大家一起LINQ吧入门教程系列1LinqtoSql(一):DataConte某t与实体LinqtoSql(二):增删改LinqtoSql(三):查询句法LinqtoSql(四):存储过程LinqtoSql(五):探究特性LinqtoSql(六):并发与事务LinqtoSql(七):继承与关系Linqtoql(八):其它入门教程系列2LINQ体验(1)——ViualStudio2022新特性我平时利用课余零碎时间来学习3.5、LINQ、Silverlight、3.5E某tenion等新东西,通过笔记形式来记录自己所学的历程,也给大家一起学习ViualStudio2022和.NET3.5提供一个平台,为保证此系列的完整性,我打算先依次介绍一下C#3.0新语言特性和改进,然后从一条一条LINQ语句分析来贯穿LINQ的知识点……LINQ体验(2)——C#3.0新语言特性和改进(上篇)LINQ体验(3)——C#3.0新语言特性和改进(下篇)LINQ体验(4)——LINQ简介和LINQtoSQL语句之WhereLINQ是LanguageIntegratedQuery的简称,它是集成在.NET编程语言中的一种特性。

已成为编程语言的一个组成部分,在编写程序时可以得到很好的编译时语法检查,丰富的元数据,智能感知、静态类型等强类型语言的好处。

并且它同时还使得查询可以方便地对内存中的信息进行查询而不仅仅只是外部数据源。

…LINQ体验(5)——LINQtoSQL语句之Select/Ditinct和Count/Sum/Min/Ma某/AvgLINQ体验(6)——LINQtoSQL语句之Join和OrderByLINQ体验(7)——LINQtoSQL语句之GroupBy/Having和E某it/In/Any/All/Contain我们继续讲解LINQtoSQL语句,这篇我们来讨论GroupBy/Having操作符和E某it/In/Any/All/Contain操作符。

LINQ to SQL 数据上下文

LINQ to SQL 数据上下文

LINQ to SQL 数据上下文1. 概述通过LINQ to SQL基础篇我们对LINQ to SQL有了一个概要的认识,本文我们来认识在LINQ to SQL 中处于非常重要地位的一个对象——DataContext(数据上下文),它位于System.Data.Linq命名空间下,是实体和数据库之间的一个桥梁。

DataContext主要提供了如下几个功能:A.记录生成的SQL语句,这对于我们调试LINQ to SQL时是非常有用的,可以通过查看记录的SQL语句,来分析LINQ to SQL在数据库中执行了什么。

B.执行SQL语句。

LINQ to SQL通过查询句法和Lambda表达式提供了强大的功能,能完成T-SQL 90%以上的功能,如果在开发中,遇到非常复杂的查询,无法用查询句法或者Lambda表达式来实现,你可以使用自己熟悉的T-SQL来完成。

C.创建、删除数据库。

在第一篇中我就说过,LINQ to SQL是一个轻量级的O/R Mapping,使用LINQ to SQL可以不用考虑数据库表之间的关系,直接考虑你的业务对象关系,设计好实体类之后,通过DataContext可以自动创建数据库。

2. 创建DataContext在DataContext中,提供了如下四种重载方式的构造函数,就是说我们可以通过四种方式来创建一个DataContext对象:Code1:public DataContext(IDbConnection connection);public DataContext(string fileOrServerOrConnection);public DataContext(IDbConnection connection, MappingSource mapping);public DataContext(string fileOrServerOrConnection, MappingSource mapping);我们经常使用的有两种:一是使用连接字符串,作为DataContext构造函数的参数:Code2public DataContext CreateDataContext(){DataContext db = new DataContext(@"Server=Esint-lhj\Sql2005;User Id=sa;Password=sql2005;Database=MSPetShop4");return db;}这里为了避免硬编码连接字符串,你也可以把连接字符串放在配置文件中。

VB第11章 Linq to SQL数据库操作

VB第11章  Linq to SQL数据库操作

例如,下列语句中“=”右边就是一个Lambda表达式,该表达 式递增其参数并返回递增后的值。
'Add为一个匿名类型的变量 Dim Add = Function(num As Integer) num + 1 【演练11-2】
11.2 使用LINQ查询
11.2.1 使用LINQ查询表达式 每个查询关键字对应一个LINQ查询子句,各子句都具有明确的 功能,将这些子句组合到一起就构成了一个完整且具有特定功能的 的LINQ查询。常用的LINQ查询子句及其功能说明见下表。
11.2 使用LINQ查询
11.2.2 使用LINQ方法 使用前面介绍过的LINQ查询表达式进行查询时,由于表达式语 法上的限制一些复杂的查询很难实现。为解决这一问题LINQ还提供 了一套通过使用C#代码编写的方法进行查询的方式。 1. 使用Where()方法 2. 使用Single()和SingleOrDefault()方法 3. 其它常用方法 Average()、Min()、Max()、Sum()、Skip(n)、SkipWhile(条件)
在不使用对象初始化器时,为对象的属性赋值需用如下所示的语句: Dim stu As New Student: = "zhangsan ":stu.Age = 20
若使用对象初始化器,则可在初始化对象时直接为对象的属性赋值:
若使用对象初始化器,则可在初始化对象时直接为对象的属性赋值:
'注意不要忽略了属性名前的“.”符号 Dim stu As New Students With {.StuAge = 20, .StuName = "zhangsan"}
11.2 使用LINQ查询
11.2.1 使用LINQ查询表达式 1. 最基本的LINQ查询表达式 所谓最基本的LINQ查询表达式是指表达式中仅包含一个from子 句和一个select子句。其语法格式为: From 变量 In 数据源 Select 表达式

LinQtoSQL用法详解

LinQtoSQL用法详解

LinQtoSQL⽤法详解LinQ是指集成化查询语⾔,通过映射将内的表名变为C#的类名,将列名作为属性名,将表的关系作为类的成员对象。

O--M--R O-Object对象R-Relation关系M-Mapping映射LinQ包括:LinQ to SQL,针对SQL的查询,它是⼀个带有可视化的操作界⾯的ORM⼯具。

LinQ to Object,⽤来实现对内存中集合对象的查询。

LinQ to DataSet,对强类型化或弱类型化的DataSet或独⽴的DataTable进⾏查询。

LinQ to Entity,对实体框架中EDM定义的实体集合进⾏查询。

(⼀):LinQ to SQL第⼀步:建⽴LinQ2SQL类添加⼀个新建项,选择LinQ to SQL,将⽤到的表拖进来。

第⼆步:实例化上下⽂对象,基本所有操作都是通过上下⽂对象来进⾏的。

MyDBDataContext context = new MyDBDataContext();第三步:操作⼀、增加数据:1.造⼀个要添加的数据对象:Info data = new Info();data.Code = "p211"; = "⽯头";data.Sex = false;data.Nation = "N001";data.Birthday = new DateTime(1990, 1, 2);2.在上下⽂中注册上⾯新造的对象。

.InsertOnSubmit(data);3.提交执⾏context.SubmitChanges();⼆、删除:1. 找出要删除的数据MyDBDataContext context = new MyDBDataContext();var q = .Where(p => p.Code == "p003");2. 删除注册if (q.Count() > 0){Info data = q.First();//注册context.Work.DeleteAllOnSubmit(data.Work);context.Family.DeleteAllOnSubmit(data.Family);.DeleteOnSubmit(data);}3. 提交执⾏context.SubmitChanges();三、修改:1. 找出要修改的数据MyDBDataContext context = new MyDBDataContext();var q = .Where(p=>p.Code == "p001");2. 改,不⽤注册if (q.Count() > 0){Info data = q.First();//改 = "胡⽣";data.Nation = "n001";data.Sex = false;}3. 提交执⾏context.SubmitChanges();四、查询:1.查所有MyDBDataContext context = new MyDBDataContext();//所有⼈员var q = ;//var q = from p in select p;//显⽰foreach(Info data in q){//data.Nation1:当前⼈员对应的民族对象。

asp.net使用LINQ to SQL连接数据库及SQL操作语句用法分析

asp.net使用LINQ to SQL连接数据库及SQL操作语句用法分析

本文实例讲述了使用LINQ to SQL连接数据库及SQL操作语句用法。

分享给大家供大家参考,具体如下:LINQ简介LINQ:语言集成查询(Language INtegrated Query)是一组用于c#和Visual Basic语言的扩展。

它允许编写C#或者Visual Basic代码以查询数据库相同的方式操作内存数据。

LINQ是一门查询语言,和SQL一样,通过一些关键字的组合,实现最终的查询。

LINQ的分类LINQ to ObjectLINQ to XMLLINQ to SQLLINQ to DataSetLINQ to 命名空间为System.Linq;LINQ查询语法:from 临时变量in 集合对象或数据库对象where 条件表达式[orderby条件][group by 条件]select 临时变量中被查询的值例:from c in Student select c;假设Student是一个数据库表对应的一个实体类则查询语句为:from c in Student select c;//整表查询from c in Student where =="张三" select c;//查询姓名为张三的所有信息其中C为临时变量,可任意取。

查询几个字段1、查询student表中的几个字段代码如下:var query=from c in student select new {c.number,,c.age};2、查询student表中的几个字段,并重新设定列名代码如下:var query=from c in student select new {学号=c.number,姓名=, 年领=c.age};注意事项linq查询语句必须以from子句开始,以select 子句结束。

Linq是在.NET Framework 3.5 中出现的技术,所以在创建新项目的时候必须要选3.5或者更高版本,否则无法使用。

精品IT教程LINQTOSQL基础教程及学习笔记

精品IT教程LINQTOSQL基础教程及学习笔记

LINQ TO SQL 学习笔记1. 预备知识 (3)1.1.Linq介绍 (3)1.2.隐含类型局部变量 (3)1.3.匿名类型 (4)1.4.扩展方法 (5)1.5.自动属性 (6)1.6.对象初始化器/集合初始化器 (6)mbda表达式与Lambda表达树 (7)1.8.查询句法 (9)2. DataContent与实体 (10)2.1.DataContent (10)2.2.实体类 (10)2.3.强类型DataContent (11)2.4.日志功能 (11)2.5.探究查询 (12)2.6.执行查询 (13)2.7.创建数据库 (13)2.8.使用DbDataReader数据源 (14)2.9.生成实体类 (14)3. 增删改 (15)3.1.插入(Insert) (15)3.2.更新(Update) (18)3.3.删除(Delete) (18)3.4.使用Attach更新(Update with Attach) (19)3.5.使用Attach更新和删除(Update and Delete with Attach) (21)4. 查询句法 (22)4.1.Select (22)4.2.Where (23)4.3.OrderBy (23)4.4.分页 (24)4.5.分组 (24)4.6.Distinct (25)4.7.Union (25)4.8.Contact (25)4.9.取相交项 (26)4.10.排除相交项 (26)4.11.子查询 (27)4.12.In操作 (27)4.13.Join (28)5. 存储过程 (28)5.1.普通存储过程 (28)5.2.带参数存储过程 (30)5.3.带返回值的存储过程 (30)5.4.多结果集存储过程 (30)5.5.使用存储过程新增/更新/删除数据 (31)6. 探究特性 (33)6.1.延迟执行 (33)6.2.DataLoadOptions (33)6.3.DataLoadOptions限制 (34)6.4.主键缓存 (35)6.5.DataContent隔离 (35)7. 并发与事务 (35)7.1.检测并发 (35)7.2.解决并发 (36)7.3.事务处理 (38)8. 其他 (40)Linq学习笔记(1.6)——ToArray、ToList、ToDictionary、OfType (40)1.预备知识1.1.Linq介绍LINQ是Language Integrated Query的简称,它是集成在.NET编程语言中的一种特性。

asp.net使用LINQ to SQL连接数据库及SQL操作语句用法分析

asp.net使用LINQ to SQL连接数据库及SQL操作语句用法分析

本文实例讲述了使用LINQ to SQL连接数据库及SQL操作语句用法。

分享给大家供大家参考,具体如下:LINQ简介LINQ:语言集成查询(Language INtegrated Query)是一组用于c#和Visual Basic语言的扩展。

它允许编写C#或者Visual Basic代码以查询数据库相同的方式操作内存数据。

LINQ是一门查询语言,和SQL一样,通过一些关键字的组合,实现最终的查询。

LINQ的分类LINQ to ObjectLINQ to XMLLINQ to SQLLINQ to DataSetLINQ to 命名空间为System.Linq;LINQ查询语法:from 临时变量in 集合对象或数据库对象where 条件表达式[orderby条件][group by 条件]select 临时变量中被查询的值例:from c in Student select c;假设Student是一个数据库表对应的一个实体类则查询语句为:from c in Student select c;//整表查询from c in Student where =="张三" select c;//查询姓名为张三的所有信息其中C为临时变量,可任意取。

查询几个字段1、查询student表中的几个字段代码如下:var query=from c in student select new {c.number,,c.age};2、查询student表中的几个字段,并重新设定列名代码如下:var query=from c in student select new {学号=c.number,姓名=, 年领=c.age};注意事项linq查询语句必须以from子句开始,以select 子句结束。

Linq是在.NET Framework 3.5 中出现的技术,所以在创建新项目的时候必须要选3.5或者更高版本,否则无法使用。

linq to sql

linq to sql

1
ORM框架
大部分ORM框架将数据库的关系模型抽象成对象模型后,对 数据库的访问就只能通过对象模型以标准的对象访问方式 来进行象;而LINQ to SQL不同,它不仅允许以标准的 对象访问方式来访问对象模型,而且可以使用非常类似于 SQL语句的查询表达式来操作对象模型。
什么是LINQ to SQL
LINQ to SQL全称基于关系数据的.NET语言集成查询, 用于以对象形式管理关系数据,并提供了丰富的查询功能 。其建立于公共语言类型系统中的基于SQL的模式定义的 集成之上,当保持关系型模型表达能力和对底层存储的直 接查询评测的性能时,这个集成在关系型数据之上提供强 类型 LINQ to SQL是.NET3.0版本以上的一个组件,用于对 LINQ与SQL查询进行“语言翻译”。LINQ to SQL就 是LINQ聘请的翻译大师。这个翻译大师可以将LINQ查询 翻译成SQL查询。LINQ to SQL首先通过编程语言创建 对象模型,接着通过程序实时翻译成SQL查询,以映射到 关系数据库的数据模型,从而实现查询操作关系型数据。

LINQ to SQL LINQ to DataSet LINQ to Entities
LINQ的分类
LINQ to SQL

面向SQL Server 数据库。
LINQ to XML

面向XML 文档。
面向 数据集。
LINQ to DataSet

LINQ to Objects
3 DataContex对象
3.3 CreateDatabase方法 CreateDatabase方法用于在数据库服务器上根据实体 类映射信息或者XML映射文件创建一个数据库,其方法原 型定义如下。 void CreateDatabase() CreateDatabase方法的使用非常简单,没有参数,只 是根据映射信息创建一个包含若干物理表的数据库。 3.4 DatabaseExists方法 DatabaseExists方法用于判断DataContex对象使用的数据 库是否存在,其方法原型定义如下。 bool DatabaseExists() 此方法的使用非常简单,没有参数,只是简单地根据 DataContex的初始化数据库连接信息判断数据库是否存在 。如果存在就返回true,否则返回false。
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

LINQ to SQL快速上手step by step前言最近接连遇到几个朋友问我同一个问题,就是关于.NET平台上ORM框架的选择。

我想在这个讲求效率的时代,谁也不想手写SQL或存储过程去访问数据库了。

大家都知道,在Java平台上,ORM这一块基本是Hibernate的天下。

当然,相对轻量级的iBatis也有不错的表现。

不过谈到.NET平台,ORM框架似乎相对混乱了点。

很多朋友问我的时候,往往会这样问:NHibernate、NBear和Castle该选择哪个?而当我反问:为什么不适用微软自带的Linq to Sql呢?对方经常会迷茫和不解。

我觉得这是个很奇怪的现象。

依照我个人的实践,我认为当需要快速构建一个中小型项目时,Linq to Sql是一个很好的选择。

你至少有以下理由可以选择它:i. 它是微软自己的产品,和.NET平台有着天生的适应性。

如果你使用.NET Framework3.5和VS2008开发环境,它本身就集成在里面了,同时VS2008对于Linq to Sql给予了诸多方便的支持。

使用它,你不仅在开发和部署时不用考虑第三方库,更可以尽情享受VS2008带来的种种方便。

ii. 上手十分容易,使用十分轻松,通常,你不需要编写一行代码,也不用写任何XML 配置,完全通过可视化拖拽就能完成ORM层的构建。

iii. 功能丰富,使用便捷。

当轻松构建好ORM层后,你就可以更轻松的操纵数据库了。

Linq to Sql提供了丰富的功能,完全可以满足日常数据访问的需求。

使用方法也非常简单、灵活。

有这么好的理由,我真想不通为什么那么多人不愿去选择它。

我想来想去,也许有两个重要原因,一是把LINQ和Linq to Sql混为一谈了,二是受前段时间“LINQ已死”的误导,觉得微软已经抛弃Linq to Sql了。

关于这两点,我就不细说了,简略澄清一下:首先,LINQ是从.NET Framework3.0开始,.NET平台上引入的一种新式语言特性,狭义一点,你可以讲它理解成一种新式语法,主要是针对迭代数据操作的,所以,也许LINQ 叫做“数据迭代引擎(Data Iterative Engine)”更合适,之所以不着样命名,我想微软可能不愿意让自己产品的简写为“DIE”吧。

:-)而Linq to Sql是LINQ在数据库访问方面的一个应用框架,完全是两码事。

其次,关于微软会不会放弃Linq to Sql,客观说,可能会,因为微软下一步主推的ORM解决方案是Entity Framework。

不过这并不妨碍你学习使用Linq to Sql,原因如下:第一,考虑到兼容性问题,微软绝对不会把Linq to Sql从.NET Framework中拿掉的,所以你不用怕现在用Linq to Sql写的程序以后不能运行了。

第二,即使微软不更新Linq to Sql了,但它现在的功能,已经足够满足我们日常需要了,相比重量级的Entity Framework,如果你只是做一个中小型项目,并且很注重开发效率和学习曲线,为什么不选择可爱的Linq to Sql呢?好的,上面废话说了不少,下面正式开始吧。

本文不是一篇关于Linq to Sql的大百科,写本文的目的,是引导大家快速上手Linq to Sql,所以不可能面面俱到去讲解Linq to Sql。

不过根据80-20定律,学会了本文的内容,基本就可以应付80%的工作了。

另外,延续我一贯的风格,本文将通过案例的方式帮大家上手Linq to Sql。

案例是一个“公告发布程序”。

下面我们开始!Step1:建立数据库在使用Linq to Sql前,我们要将相应的数据库建好。

在这个Demo中,使用的数据库是SQL Server Express 2005。

我们首先建立一个叫的数据库MyBulletin,及两个数据表:Category和Bulletin,分别表示公告的分类和公告,建立方法不再赘述。

至于两个表的具体字段请参看图1。

图1、数据表结构其中Category和Bulletin存在一个一对多的关联,表示一个分类下可以有多条公告。

Step2:建立LINQ to SQL Classes文件数据建好后,我们需要建立LINQ to SQL Classes文件。

这种文件是Linq to Sql框架的主要文件,后面自动生成的实体类和ORM代码都存在于这个文件中。

我们打开VS2008,新建一个C# Class Labrary工程,名称为LinqToSqlDemo.Orm,建好后在工程上单击右键,选择“Add”->“New Item”,在文件类型中选择“LINQ to SQL Classes”,文件名命名为“DataClasses.dbml”,如图2所示。

图2、新建LINQ to SQL Classes文件Step3:根据数据库表自动生成代码当建好LINQ to SQL Classes后,VS主界面中自动打开了这个文件。

可以看到,这个文件实际是一个设计文件,目前还不包含任何代码和元素。

下一步就是利用我们刚才的数据库自动生成ORM代码了。

打开Server Explorer面板。

一般它位于VS的左上角,如果没有,请到View菜单中去打开。

然后在Date Connections上右键单击,选择“Add Connection”,从这里添加对数据库MyBulletin的连接。

图3、添加数据库连接如图3所示,在Server name中填入SQL Server数据库服务的名字,如果使用的是SQL Server Express 2005,服务名一般是“计算机名\SQLEXPRESS”的格式,然后在“Select or enter a database name”中选择MyBulletin,单击“OK”,就连上我们所需的数据库了。

这时,展开这个连接下的Tables节点,应该能看到Category和Bulletin两个表,选中两个表,将它们拖到DataClasses.dbml的设计区,就会看到如图4所示的样子。

图4、设计视图然后,按Ctrl+S保存,OK!ORM构建完了!没有骗你,所有需要的代码已经生成完成,现在可以使用它们操作MyBulletin数据库了。

不要怀疑,Linq to Sql使用起来就是这么轻松加愉快,不需要写一行代码,也不需要写一个XML字符,ORM就构建完了!我知道你没看到生成的东西可能不太放心,那么你可以在Solution Explorer里展开DataClasses.dbml节点,看到里面的DataClasses.designer.cs文件没,打开它,里面就是刚才自动生成的代码,我们的数据访问操作就靠这些代码了。

另外顺表提一下,数据库的连接字符串放在工程根目录下的app.config文件里,这也是自动生成的,打开它,就可以看到连接字符串。

以后如果要修改连接字符串,就修改这里。

好了,ORM构建好了,下面我们看看怎么用。

Step4:使用Linq to Sql访问数据库我们首先新建一个工程。

为了简单起见,我们就直接建立一个C# Console Application测试我们的ORM吧。

将这个工程命名为LinqToSqlDemo.Test。

当然,建好工程后,不要忘了添加对工程LinqToSqlDemo.Orm的引用,还要添加对“System.Data.Linq”命名空间的引用。

然后,我们打开Program.cs文件,将其中的内容替换为如下测试代码。

using System;using System.Collections.Generic;using System.Data.Linq;using System.Linq;using System.Text;using LinqToSqlDemo.Orm;namespace LinqToSqlDemo.Test{class Program{private static DataClassesDataContext dataContext = new D ataClassesDataContext();private static void Output(){//输出分类信息foreach (Category c in dataContext.Categories){Console.WriteLine("分类" + c.ID + ":" + ); }//输出体育新闻下的公告信息Category categorySport = dataContext.Categories.Singl e(c => == "体育新闻");foreach (Bulletin b in categorySport.Bulletins){Console.WriteLine("标题:" + b.Title);Console.WriteLine("内容:" + b.Content);Console.WriteLine("发布日期:" + b.Date);Console.WriteLine("所属分类:" + ); }}private static void TestInsert(){//生成分类实体类Category category1 = new Category(){Name = "国际要闻"};Category category2 = new Category(){Name = "体育新闻"};Category category3 = new Category(){Name = "财经快报"};//生成公告实体类Bulletin bulletin1 = new Bulletin(){Content = "曼联晋级冠军杯四强",Date = DateTime.Now,Title = "曼联晋级冠军杯四强"};Bulletin bulletin2 = new Bulletin(){Content = "18:00直播亚冠首尔VS山东,敬请期待!!!", Date = DateTime.Now,Title = "18:00直播亚冠首尔VS山东"};//将公告加入相应分类category2.Bulletins.Add(bulletin1);category2.Bulletins.Add(bulletin2);//加入数据库dataContext.Categories.InsertOnSubmit(category1);dataContext.Categories.InsertOnSubmit(category2);dataContext.Categories.InsertOnSubmit(category3);dataContext.SubmitChanges();}private static void TestDelete(){dataContext.Categories.DeleteOnSubmit(dataContext.Cat egories.Single(c => == "国际要闻"));dataContext.SubmitChanges();}private static void TestUpdate(){Category categoryFinance = dataContext.Categories.Sin gle(c => == "财经快报"); = "财经新闻";dataContext.SubmitChanges();}static void Main(string[] args){Console.WriteLine("==============================Linq to SQL 测试==============================");Console.WriteLine();Console.WriteLine("==============================测试I nsert==============================");Console.WriteLine();TestInsert();Output();Console.WriteLine("==============================测试D elete==============================");Console.WriteLine();TestDelete();Output();Console.WriteLine("==============================测试U pdate==============================");Console.WriteLine();TestUpdate();Output();Console.ReadLine();}}}一下子看不懂上述代码页没有关系,稍候我们会解释一下。

相关文档
最新文档