新客网WWW.XKER.COM:致力做中国最专业的网络学院!
学院: 操作系统 - 网络应用 - 服务器 - 网络安全 - 工具软件 - 办公软件 - Web开发 - 数据库 - 网页设计 - 图形图像 - 媒体动画 - 硬件学堂 - 存储频道 - QQ专区
您的位置:首页 > 软件开发 > 数据库 > 数据库综合 > 正文:LINQ to SQL 基本数据操作

LINQ to SQL 基本数据操作

新客网 XKER.COM 2008-03-14 来源:小杰的blog 收藏本文
首先需要讲一下 DataContext 类 。
这个类是 LINQ to SQL 框架的主入口点。DataContext 是通过数据库连接映射的所有实体的源。

要在数据库操作上玩 SQL 除了 DataContext 还需要一个数据表的实体类。

在VS 2008 里面,可以直接使用生成 "LINQ to SQL 类" 来解决懒人的动手问题。

添加 "LINQ to SQL 类" 后,可以直接使用 "服务资源管理器" 添加所需要的数据表到 "LINQ to SQL 类",
这样就能直接生成 DataContext 的派生类和表的实体类。


下面这个例子,使用 Northwind 数据库。
    
    // NorthwindDataContext 是 DataContext 派生类, 用于连接数据库与实体
    NorthwindDataContext n = new NorthwindDataContext(
@"Data Source=.;Initial Catalog=Northwind;Integrated Security=True");
    
    
// 操作 Orders 数据表
    var s = from n1 in n.Orders
            
where n1.OrderID % 10 == 0
            select 
new
            
{
                ID 
= n1.OrderID,
                Name 
= n1.ShipName
            }
;

    
foreach (var s1 in s)
    
{
        Console.Write(s1.ID);
        Console.Write(
" | ");
        Console.Write(s1.Name);
        Console.WriteLine();
    }

    

    Console.ReadKey();
    
/*
10300 | Magazzini Alimentari Riuniti
10400 | Eastern Connection
10500 | La maison d'Asie
10600 | Hungry Coyote Import Store
10700 | Save-a-lot Markets
10800 | Seven Seas Imports
10900 | Wellington Importadora
11000 | Rattlesnake Canyon Grocery
*/



插入数据:

若要执行 SQL Insert,只需向您已创建的对象模型添加对象,然后对 DataContext 调用 SubmitChanges 即可。

    NorthwindDataContext n = new NorthwindDataContext(
@"Data Source=.;Initial Catalog=Northwind;Integrated Security=True");

    
// 建立对Region表的LINQ查询
    var Regions = from n1 in n.Region
                  select n1;

    
// 向Region插入数据
    Region r = new Region();
    r.RegionID 
= 999;
    r.RegionDescription 
= "test";
    n.Region.InsertOnSubmit(r); 
// 添加记录到
    n.SubmitChanges();  // 通知数据库更改记录

    
// 开始查询,延迟执行
    foreach (var Region in Regions)
    
{
        Console.Write(Region.RegionID);
        Console.Write(
" | ");
        Console.Write(Region.RegionDescription);
        Console.WriteLine();
    }
            

    Console.ReadKey();

/*
1 | Eastern
2 | Western
3 | Northern
4 | Southern
999 | test
*/



  这里创建一个新示例数据库 DBTest.mdf
  数据库只有一个 Table 表
  CREATE TABLE [Table]
    (
    ID 
int NOT NULL IDENTITY (11PRIMARY KEY,
    Value 
varchar(50NULL
    )

    
    并为这个数据表添加一个"LINQ to SQL 类",该文件命名为:TestDB.dbml
    

更新数据:


  // 把数据库中ID等于10记录的值修改为"null"
  static void Main()
  
{

      TestDBDataContext TestDB 
= new TestDBDataContext(@"路径"DBTest.mdf");

      var L 
= from v in TestDB.Table
              
where v.ID == 10
              select v;

      
foreach (var I in L)
      
{
          I.Value 
= "null"//修改值
      }

      TestDB.SubmitChanges(); 
// 向数据库提交刷新

      
      
foreach (var I in L)  // 显示修改后的值
      {
          Console.WriteLine(I.Value);
      }

      
      Console.ReadKey();
  }


删除记录:



  
// 把数据库中value为"null"的记录删除
  static void Main()
  
{

      TestDBDataContext TestDB 
= new TestDBDataContext(@"路径"DBTest.mdf");

      var L 
= from v in TestDB.Table
              
where v.Value == "null"
              select v;


      
foreach (var I in L)
      
{
          TestDB.Table.DeleteOnSubmit(I); 
// 删除记录
      }

      TestDB.SubmitChanges(); 
// 向数据库提交刷新


      Console.ReadKey();
  }


存储过程:

  存储过程:
    ALTER PROCEDURE insertToTable
      
@value varchar(50)
    
AS
      
insert into [Table] (value) values (@value)
      
RETURN

 
  在"服务器资源管理器"中打开这个存储过程,然后拖到刚才的"LINQ to SQL 类" -- TestDB.dbml 中,
在TestDB.designer.cs文件里面,IDE自动在 class TestDBDataContext(DataContext的派生类)
里面为这个insertToTable存储过程添加了如下方法代码:
 
        [Function(Name="dbo.insertToTable")]
        
public int insertToTable([Parameter(DbType="VarChar(50)")] string value)
        
{
            IExecuteResult result 
= this.ExecuteMethodCall(this, ((MethodInfo)(MethodInfo.GetCurrentMethod())), value);
            
return ((int)(result.ReturnValue));
        }

        
然后只需要在客户端使用一下这个方法,就完成了存储过程的调用:
    static void Main()
    
{

        TestDBDataContext TestDB 
= new TestDBDataContext(@"路径"DBTest.mdf");

        TestDB.insertToTable(
"AppTest");  // 使用InsertToTable存储过程为"Table"表添加一行记录

    }
收藏】 【评论】 【推荐】 【投稿】 【打印】 【关闭
发表评论
要记得去论坛讨论,点击注册新会员匿名评论
评论内容:不能超过250字,需审核后才会公布,请自觉遵守互联网相关政策法规。
阅读排行
随机推荐
实用信息推荐