1.4.3 LINQ to SQL 对数据库应用查询表达式

本文介绍如何使用LINQ to SQL配置数据库连接,创建产品和供应商表,并通过查询实现产品与供应商的关联操作。
/****** Object:  Table [dbo].[Product]    Script Date: 04/24/2012 23:58:49 ******/
IF  EXISTS (SELECT * FROM sys.objects WHERE object_id = OBJECT_ID(N'[dbo].[Product]') AND type in (N'U'))
DROP TABLE [dbo].[Product]
GO

USE [C:\USERS\JON\DOCUMENTS\COMPUTING\AUTHORING\CSHARP 2 AND 3\BOOK\CODE\DATABASES\LINQDEMO.MDF]
GO

/****** Object:  Table [dbo].[Product]    Script Date: 04/24/2012 23:58:49 ******/
SET ANSI_NULLS ON
GO

SET QUOTED_IDENTIFIER ON
GO

CREATE TABLE [dbo].[Product](
    [ProductID] [int] IDENTITY(1,1) NOT NULL,
    [Name] [nvarchar](50) NOT NULL,
    [Price] [decimal](18, 2) NOT NULL,
    [SupplierID] [int] NOT NULL
) ON [PRIMARY]

GO


/****** Object:  Table [dbo].[Supplier]    Script Date: 04/24/2012 23:58:55 ******/
IF  EXISTS (SELECT * FROM sys.objects WHERE object_id = OBJECT_ID(N'[dbo].[Supplier]') AND type in (N'U'))
DROP TABLE [dbo].[Supplier]
GO

USE [C:\USERS\JON\DOCUMENTS\COMPUTING\AUTHORING\CSHARP 2 AND 3\BOOK\CODE\DATABASES\LINQDEMO.MDF]
GO

/****** Object:  Table [dbo].[Supplier]    Script Date: 04/24/2012 23:58:55 ******/
SET ANSI_NULLS ON
GO

SET QUOTED_IDENTIFIER ON
GO

CREATE TABLE [dbo].[Supplier](
    [SupplierID] [int] IDENTITY(1,1) NOT NULL,
    [Name] [nvarchar](50) NOT NULL
) ON [PRIMARY]

GO
添加 LINQ to SQL 文件,配置数据库连接,之后把两个表拖到界面上,后台类名改为 LinqDemoDataContext
 
            using (LinqDemoDataContext db = new LinqDemoDataContext())
            {
                var filtered = from p in db.Product
                               join s in db.Supplier
                                  on p.SupplierID equals s.SupplierID
                               where p.Price > 10
                               orderby s.Name, p.Name
                               select new
                               {
                                   SupplierName = s.Name,
                                   ProductName = p.Name
                               };
                foreach (var v in filtered)
                {
                    Console.WriteLine("Supplier={0};Product={1}", v.SupplierName, v.ProductName);
                }
            }

 

转载于:https://www.cnblogs.com/xiacy/archive/2012/04/25/2469120.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值