博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
LINQ to SQL 建立实体类
阅读量:6257 次
发布时间:2019-06-22

本文共 6275 字,大约阅读时间需要 20 分钟。

使用LINQ to SQL时,需要首先建立用于映射数据库对象的模型,也就是实体类。在运行时,LINQ to SQL 根据LINQ表达式或查询运算符生成SQL语句,发送到数据库进行操作。数据库返回后,LINQ to SQL负责将结果转换成实体类对象。

建立实体类的方法有很多,例如LINQ to SQL设计器,手动编码建立,使用XML文件映射,使用命令行工具SqlMetal生成等。其中最方便的就是LINQ to SQL设计器。

1.使用LINQ to SQL设计器建立实体类         

在一个示例用的Demo控制台程序中添加一个“基于服务的数据库”Database1.mdf,建立一张tb_GuestInfo的表。该表的详细如下:

下面的所有建立方式,都用的这个数据库。

在项目中添加一个LINQ to SQL类,采用默认的名称DataClasses1.dbml,如下:

 将tb_GuestInfo表拖到界面上,保存。

 OK,编写相关代码如下,实现增删改查:

using System;using System.Collections.Generic;using System.Linq;using System.Text;namespace LINQ_To_SQL自定义数据库和实体类{    ///     /// 实体类的建立___1.VS建立实体类    ///     class Program    {        static void Main(string[] args)        {            //            DataClasses1DataContext dc = new DataClasses1DataContext();                        //1.查询            IQueryable
query = from p in dc.tb_GuestInfo where p.Name != "XXX" select p; foreach (var g in query) { Console.WriteLine("{0} {1} {2} {3}",g.Id,g.Name,g.Age ,g.Tel ); } Console.WriteLine("-----------------"); Console.ReadKey(false); //2.增加一条记录 tb_GuestInfo gInfo = new tb_GuestInfo() { Id = 9, Name = "M&M", Age = 40, Tel = "135****5555" }; dc.tb_GuestInfo.InsertOnSubmit(gInfo); dc.SubmitChanges(); foreach (var g in query) { Console.WriteLine("{0} {1} {2} {3}",g.Id , g.Name, g.Age, g.Tel); } Console.WriteLine("-----------------"); Console.ReadKey(false); //3.删除 var query_itemToDelete = from g in dc.tb_GuestInfo where g.Name == "M&M" select g; foreach (var g in query_itemToDelete) { dc.tb_GuestInfo.DeleteOnSubmit(g); } dc.SubmitChanges(); foreach (var g in query) { Console.WriteLine("{0} {1} {2} {3}", g.Id, g.Name, g.Age, g.Tel); } Console.WriteLine("-----------------"); Console.ReadKey(false); //4.修改 var query_itemToUpdate = from g in dc.tb_GuestInfo where g.Name.Contains("DebugLZQ") select g; foreach (var g in query_itemToUpdate) { g.Name = g.Name + "A"; } dc.SubmitChanges(); foreach (var g in query) { Console.WriteLine("{0} {1} {2} {3}", g.Id, g.Name, g.Age, g.Tel); } Console.WriteLine("-----------------"); Console.ReadKey(false); } }}

程序运行结果如下:

 2.手动建立实体类                     

实体类在多数情况下可以通过LINQ to SQL类设计器建立,当然动手建立一个简单的实体类也不是难事,并且可以更好的学习LINQ to SQL的对象模型。数据库依然是前面的示例数据库。

在项目中添加一个类GuestInfoEntity.cs,如下:

using System;using System.Collections.Generic;using System.Linq;using System.Text;using System.Data.Linq.Mapping;namespace DataContexDemo{    ///     /// 手动建立实体类    ///     [Table(Name="tb_GuestInfo")]    class GuestInfoEntity    {        [Column(IsPrimaryKey=true,DbType="Int NOT NULL IDENTITY",IsDbGenerated=true,Name="Id")]        public int ID { get; set; }        [Column(DbType = "nvarchar(20)", Name = "Name")]        public string Name{get;set;}        [Column(DbType = "int", Name = "Age")]        public int Age { get; set; }        [Column(DbType = "nvarchar(20)", Name = "Tel")]        public string Tel { get; set; }    }}

编写示例代码,注意需要引入System.Data.Linq.dll:

using System;using System.Collections.Generic;using System.Linq;using System.Text;using System.Data.Linq;//关注namespace DataContexDemo{    class Program    {        static void Main(string[] args)        {            //2.手动建立实体类            //            //连接字符串            string constring = @"Data Source=.\SQLEXPRESS;AttachDbFilename=E:\Visual Studio 2010\LINQ_to_SQL\LINQ_To_SQL自定义数据库和实体类\Database1.mdf;Integrated Security=True;User Instance=True";            DataContext dc = new DataContext(constring);            Table
tb = dc.GetTable
(); var query = tb.AsEnumerable(); foreach (var q in query) { Console.WriteLine("{0} {1} {2} {3}",q.ID,q.Name,q.Age,q.Tel ); } Console.ReadKey(); } }}

程序运行如下:

 3.使用XML映射文件建立实体类                         

 实体类的映射除了使用内联Attribute外,还可以建立一个包含映射信息的XML文件,此文件生成System.Data.Linq.Mapping.XmlMappingSource对象,作为DataContext对象构造方法的参数。

这个XML文件只有一个根节点---Database元素,用来映射的数据库信息。Database元素包含一个或多个Table元素,用于映射数据库表的信息,Table元素由一个Type元素和多个Column元素(或Association元素)组成。Type元素用来指定实体类,Column元素用来指定列信息,Association元素用来映射数据库关系。

在项目中添加一个XML文件,采用默认名称XMLFile1.xml,内容如下:

这个XML文件包含类全部的映射信息,下面建立映射的类GuestInfoEntity.cs:

using System;using System.Collections.Generic;using System.Linq;using System.Text;namespace LINQtoSQL建立实体类_XML{   public  class GuestInfoEntity    {               public int ID { get; set; }                public string Name { get; set; }               public int Age { get; set; }                public string Tel { get; set; }    }}

编写示例代码,同样需要引入System.Data.Linq.dll:

using System;using System.Collections.Generic;using System.Linq;using System.Text;using System.Data.Linq;using System.Data.Linq.Mapping;using System.IO;//namespace LINQtoSQL建立实体类_XML{    class Program    {        static void Main(string[] args)        {            string constring = @"Data Source=.\SQLEXPRESS;AttachDbFilename=E:\Visual Studio 2010\LINQ_to_SQL\LINQ_To_SQL自定义数据库和实体类\Database1.mdf;Integrated Security=True;User Instance=True";            XmlMappingSource map = XmlMappingSource.FromXml(File.ReadAllText("XMLFile1.xml"));            DataContext dc = new DataContext(constring, map);            Table
tb = dc.GetTable
(); var query = tb.AsEnumerable(); foreach (var g in query) { Console.WriteLine("{0} {1} {2} {3}",g.ID,g.Name,g.Age,g.Tel ); } Console.ReadKey(); } }}

程序的运行如下:

 

 

http://www.cnblogs.com/DebugLZQ/archive/2012/11/14/2770449.html

你可能感兴趣的文章
Server 2008 R2 AD RMS完整部署:RMS部署篇
查看>>
SFB 项目经验-45-用培训课件当运维文档,聪明
查看>>
使用Kubernetes创建PHP留言板系统
查看>>
时间管理,从洗碗开始
查看>>
我用EDM卖约会秘籍的半个月
查看>>
运营这个职业的诞生缘由「社区运营入门系列④」
查看>>
在VMM2012R2中使用二代虚拟机创建的模板无法创建虚拟机的解决方法
查看>>
大道至简 电话号码重新成为O2O新宠
查看>>
Office 365离线安装
查看>>
jar包与was版本不兼容怎么办
查看>>
将Windows Server 2008 R2网络升级到Windows Server 2012
查看>>
修改计算机名的注意事项
查看>>
WIN7关闭共享后怎样去掉图标上的小锁
查看>>
SRV记录注册不成功的可能的原因
查看>>
一步完成 MySQL 向 Redis 迁移
查看>>
【VMC实验室】在QCloud上创建您的SQL Cluster(4)
查看>>
我的友情链接
查看>>
卢松松:每个网站都该有个监测服务
查看>>
Memcache与MySQL并肩作战
查看>>
使用Android模拟器测试Linux驱动(1)
查看>>