LINQ to SQL
来源:互联网 发布:vissim仿真软件下载 编辑:程序博客网 时间:2024/06/05 08:54
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 toSql是两个概念,Linq to SQL是Linq在数据库访问方面的一个应用框架。
3.1 Linq to SQL数据查询
LINQ to SQL Classes文件是Linq to Sql框架的主要文件,后面自动生成的实体类和ORM代码都存在于这个文件中
创建文件的步骤是
(1)在项目中添加Linq to SQL 类,我们取名为MySchool.dbml。
(2)将数据库表托至Myshool .dbml设计视图中(ORM),如图:
(3)使用Linq to Sql访问数据库
MySchoolDataContext MSDC = new MySchoolDataContext();
var result = from stu in MSDC.student select new { stu.name, stu.age, stu.sex, stu.id };
//或者采用方法语法
//var result = MSDC.student.Select(stu => new { stu.name, stu.age, //stu.sex, stu.id });
foreach (var stu in result)
{
Console.WriteLine(stu);
}
访问数据库的第一步是创建DataContext类的一个实例,DataContext是ORM中创建的dbml文件的编译类。这个对象相当于一个数据库的Gateway,所有的操作都是通过它进行的。这个对象的名字是“LINQ to SQL Classes文件名+‘DataContext’”,这里,就是MySchoolDataContext了。它和普通对象一样,直接实例化就行了。
取得DataContext对象后,每个数据表就会映射到其中一个集合属性,例如Student表映射到dataContext.student,这是一个集合属性,每一个元素是一个实体类,代表此表中的一条记录。实体类名和表名相同。实体类的字段自然就映射到对应表的字段。
ORM处理支持单表之外还支持存在关系的多表。我们在MySchool.dbml中添加Scores表,如图所示,
代码如下
MySchoolDataContext MSDC = new MySchoolDataContext();
var result = from stu in MSDC.student select new { stu.name, stu.age, stu.sex, stu.id,stu.scores };
//或者采用方法语法
//var result = MSDC.student.Select(stu => new { stu.name, stu.age, stu.sex, stu.id,stu.scores });
foreach (var stu in result)
{
Console.Write("姓名:{0},年龄:{1},性别:{2},",stu.name,stu.age,stu.sex);
foreach (var score in stu.scores)
{
Console.WriteLine("java:{0},html:{1}",score.java,score.html);
}
}
还可以这样写
var result = from stu in MSDC.student from sc in MSDC.scores where stu.id == sc.id select new { stu.name, stu.age, stu.sex, stu.id, sc.java,sc.html };
foreach (var stu in result)
{
Console.WriteLine("姓名:{0},年龄:{1},性别:{2},Java分数:{3},HTML分数:{4}", stu.name, stu.age, stu.sex,stu.java,stu.html);
}
3.2 数据绑定
3.3 更新数据
LINQ to SQL 支持对实体实例使用INSERT、DELETE 和UPDATE 操作符,对实体集使用EntitySet.Add(instance)、EntitySet.Remove(instance)方法,以及对实体属性值进行更改。SubmitChanges 方法将更改的实体存储到数据库中
3.3.1 添加数据
MySchoolDataContext msdc = new MySchoolDataContext();
student wxb = new student();
wxb.name = "韦小宝";
wxb.age = 45;
wxb.sex = "女";
msdc.student.InsertOnSubmit(wxb);
msdc.SubmitChanges();
3.3.2 更改数据
MySchoolDataContext msdc = new MySchoolDataContext();
var updatastu = (from stu in msdc.student where stu.id == 5 select stu).First();
updatastu.name = "双儿";
msdc.SubmitChanges();
3.3.3 删除数据
MySchoolDataContext msdc = new MySchoolDataContext();
var delstu = (from stu in msdc.student where stu.id == 5 select stu).First();
msdc.student.DeleteOnSubmit(delstu);
msdc.SubmitChanges();
3.4 Linq Over DataSet
var result=数据表. AsEnumerable();
foreach( var obj in result)
{
Console.WriteLine(obj[“ColumnName”]);
}
- linq,linq to sql
- Linq初探--Linq to SQL
- LINQ to SQL 学习
- 什么是Linq to sql
- 使用LINQ to SQL
- 深入LINQ to SQL
- Linq To Sql注意事项
- Linq to SQL:基础知识
- LINQ to SQL实例
- 使用LINQ to SQL
- LINQ to SQL语句
- Linq to sql(一)
- LINQ to SQL语句
- LINQ TO SQL--insert
- LINQ TO SQL--delete
- LINQ TO SQL--update
- LINQ TO SQL--select
- Linq to SQL 资源
- Android Codec 集成和 video Overlay
- 怎样使用orapwd新建口令文件
- 静态代码块(static block)
- gSOAP简单使用例子
- 贪婪算法之0/1背包问题+读数据结构算法与应用-C++语言描述
- LINQ to SQL
- android 资源引用的例子
- AjaxPro使用说明
- 《OpenGL编程基础》第二章笔记1
- gSOAP简单多线程服务器程序
- c++返回引用
- 学习 链接
- 斐波那契序列的基本实现
- 最长公共子序列