LINQ to SQL

LINQtoSQL

当需要快速构建一个中小型项目时,LinqtoSQL是一个很好的选择。你至少有以下理由可以选择它:

i.它是微软自己的产品,和.NET平台有着天生的适应性。如果你使用.NETFramework3.5VS2008开发环境,它本身就集成在里面了,同时VS2008对于LinqtoSQL给予了诸多方便的支持。使用它,你不仅在开发和部署时不用考虑第三方库,更可以尽情享受VS2008带来的种种方便。

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

iii.功能丰富,使用便捷。当轻松构建好ORM层后,你就可以更轻松的操纵数据库了。LinqtoSQL提供了丰富的功能,完全可以满足日常数据访问的需求。使用方法也非常简单、灵活。

需要明确一点,LinqLinqtoSql是两个概念,LinqtoSQLLinq在数据库访问方面的一个应用框架。

3.1LinqtoSQL数据查询

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

创建文件的步骤是

1)在项目中添加LinqtoSQL类,我们取名为MySchool.dbml

2)将数据库表托至Myshool.dbml设计视图中(ORM),如图:

3)使用LinqtoSql访问数据库

MySchoolDataContextMSDC=newMySchoolDataContext();

varresult=fromstuinMSDC.studentselectnew{stu.name,stu.age,stu.sex,stu.id};

//或者采用方法语法

//varresult=MSDC.student.Select(stu=>new{stu.name,stu.age,//stu.sex,stu.id});

foreach(varstuinresult)

{

Console.WriteLine(stu);

}

访问数据库的第一步是创建DataContext类的一个实例,DataContextORM中创建的dbml文件的编译类。这个对象相当于一个数据库的Gateway,所有的操作都是通过它进行的。这个对象的名字是“LINQtoSQLClasses文件名+‘DataContext’”,这里,就是MySchoolDataContext了。它和普通对象一样,直接实例化就行了。

取得DataContext对象后,每个数据表就会映射到其中一个集合属性,例如Student表映射到dataContext.student,这是一个集合属性,每一个元素是一个实体类,代表此表中的一条记录。实体类名和表名相同。实体类的字段自然就映射到对应表的字段。

ORM处理支持单表之外还支持存在关系的多表。我们在MySchool.dbml中添加Scores表,如图所示,

代码如下

MySchoolDataContextMSDC=newMySchoolDataContext();

varresult=fromstuinMSDC.studentselectnew{stu.name,stu.age,stu.sex,stu.id,stu.scores};

//或者采用方法语法

//varresult=MSDC.student.Select(stu=>new{stu.name,stu.age,stu.sex,stu.id,stu.scores});

foreach(varstuinresult)

{

Console.Write("姓名:{0},年龄:{1},性别:{2},",stu.name,stu.age,stu.sex);

foreach(varscoreinstu.scores)

{

Console.WriteLine("java:{0}html{1}",score.java,score.html);

}

}

还可以这样写

varresult=fromstuinMSDC.studentfromscinMSDC.scoreswherestu.id==sc.idselectnew{stu.name,stu.age,stu.sex,stu.id,sc.java,sc.html};

foreach(varstuinresult)

{

Console.WriteLine("姓名:{0},年龄:{1},性别:{2},Java分数:{3},HTML分数:{4}",stu.name,stu.age,stu.sex,stu.java,stu.html);

}

3.2数据绑定

3.3更新数据

LINQtoSQL支持对实体实例使用INSERTDELETEUPDATE操作符,对实体集使用EntitySet.Add(instance)EntitySet.Remove(instance)方法,以及对实体属性值进行更改。SubmitChanges方法将更改的实体存储到数据库中

3.3.1添加数据

MySchoolDataContextmsdc=newMySchoolDataContext();

studentwxb=newstudent();

wxb.name="韦小宝";

wxb.age=45;

wxb.sex="女";

msdc.student.InsertOnSubmit(wxb);

msdc.SubmitChanges();

3.3.2更改数据

MySchoolDataContextmsdc=newMySchoolDataContext();

varupdatastu=(fromstuinmsdc.studentwherestu.id==5selectstu).First();

updatastu.name="双儿";

msdc.SubmitChanges();

3.3.3删除数据

MySchoolDataContextmsdc=newMySchoolDataContext();

vardelstu=(fromstuinmsdc.studentwherestu.id==5selectstu).First();

msdc.student.DeleteOnSubmit(delstu);

msdc.SubmitChanges();

3.4LinqOverDataSet

varresult=数据表.AsEnumerable();

foreach(varobjinresult)

{

Console.WriteLine(obj[“ColumnName”]);

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值