LINQ-クイックガイド

定義されたパスがないため、世界中の開発者は常にデータのクエリで問題に直面しており、SQL、Webサービス、XQueryなどの複数のテクノロジーを習得する必要があります。

Visual Studio 2008で導入され、Anders Hejlsbergによって設計されたLINQ(Language Integrated Query)を使用すると、SQL、XMLなどのクエリ言語の知識がなくてもクエリを記述できます。LINQクエリは、さまざまなデータタイプに対して記述できます。

LINQクエリの例

C#

using System;
using System.Linq;

class Program {
   static void Main() {
   
      string[] words = {"hello", "wonderful", "LINQ", "beautiful", "world"};
		
      //Get only short words
      var shortWords = from word in words where word.Length <= 5 select word;
	    
      //Print each word out
      foreach (var word in shortWords) {
         Console.WriteLine(word);
      }	 
		
      Console.ReadLine();
   }
}

VB

Module Module1
   Sub Main()
      Dim words As String() = {"hello", "wonderful", "LINQ", "beautiful", "world"}
     
      ' Get only short words
      Dim shortWords = From word In words _ Where word.Length <= 5 _ Select word
     
      ' Print each word out.
	  
      For Each word In shortWords
         Console.WriteLine(word)
      Next
	  
      Console.ReadLine()
   End Sub
End Module

上記のC#またはVBのコードをコンパイルして実行すると、次の結果が得られます。

hello 
LINQ 
world

LINQの構文

LINQには2つの構文があります。これらは以下のものです。

Lamda(メソッド)構文

var longWords = words.Where( w ⇒ w.length > 10);
Dim longWords = words.Where(Function(w) w.length > 10)

クエリ(理解)構文

var longwords = from w in words where w.length > 10;
Dim longwords = from w in words where w.length > 10

LINQの種類

LINQの種類を以下に簡単に説明します。

  • オブジェクトへのLINQ
  • LINQからXML(XLINQ)
  • LINQ to DataSet
  • LINQ to SQL(DLINQ)
  • エンティティへのLINQ

上記とは別に、Microsoftの並列LINQであるPLINQという名前のLINQタイプもあります。

.NETのLINQアーキテクチャ

LINQには3層アーキテクチャがあり、最上層は言語拡張で構成され、最下層は通常IEnumerable <T>またはIQueryable <T>汎用インターフェイスを実装するオブジェクトであるデータソースで構成されます。アーキテクチャを以下に示します。

クエリ式

クエリ式はLINQクエリに他ならず、Select、Where、OrderByなどのクエリ演算子を使用してSQLと同様の形式で表現されます。クエリ式は通常、キーワード「From」で始まります。

標準のLINQクエリ演算子にアクセスするには、名前空間System.Queryをデフォルトでインポートする必要があります。これらの式は、C#3.0であった宣言型クエリ構文内で記述されています。

以下は、データソースの作成、クエリ式の定義、およびクエリの実行で構成される完全なクエリ操作を示す例です。

C#

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;

namespace Operators {
   class LINQQueryExpressions {
      static void Main() {
      
         // Specify the data source.
         int[] scores = new int[] { 97, 92, 81, 60 };

         // Define the query expression.
         IEnumerable<int> scoreQuery = from score in scores where score > 80 select score;

         // Execute the query.
		 
         foreach (int i in scoreQuery) {
            Console.Write(i + " ");
         }
		 
         Console.ReadLine();
      }
   }
}

上記のコードをコンパイルして実行すると、次の結果が得られます。

97 92 81

拡張メソッド

.NET 3.5で導入された拡張メソッドは、静的クラスでのみ宣言され、オブジェクトにカスタムメソッドを含めて、クラスの実際のメンバーでなくてもクラスを拡張するための正確なクエリ操作を実行できます。これらも過負荷になる可能性があります。

一言で言えば、拡張メソッドは、クエリ式を従来のメソッド呼び出し(オブジェクト指向)に変換するために使用されます。

LINQとストアドプロシージャの違い

LINQプロシージャとストアドプロシージャの間には、さまざまな違いがあります。これらの違いについては、以下で説明します。

  • ストアドプロシージャは、予想される実行プランに従うため、LINQクエリよりもはるかに高速です。

  • LINQクエリの実行中の実行時エラーは、ストアドプロシージャと比較して簡単に回避できます。これは、前者がVisual StudioのIntellisenseをサポートし、コンパイル時のフルタイプチェックを備えているためです。

  • LINQでは、ストアドプロシージャの場合とは異なり、.NETデバッガーを使用してデバッグできます。

  • LINQは、さまざまなタイプのデータベースのコードを書き直すことが不可欠なストアドプロシージャとは対照的に、複数のデータベースをサポートします。

  • LINQベースのソリューションの展開は、一連のストアドプロシージャの展開と比較して、簡単でシンプルです。

LINQの必要性

LINQの前は、C#、SQL、および両方をバインドして完全なアプリケーションを形成するさまざまなAPIを学習することが不可欠でした。以来、これらのデータソースとプログラミング言語はインピーダンスの不一致に直面しています。短いコーディングの必要性が感じられます。

以下は、LINQが登場する前に、開発者がデータをクエリする際に使用したさまざまな手法の例です。

SqlConnection sqlConnection = new SqlConnection(connectString);
SqlConnection.Open();

System.Data.SqlClient.SqlCommand sqlCommand = new SqlCommand();
sqlCommand.Connection = sqlConnection;

sqlCommand.CommandText = "Select * from Customer";
return sqlCommand.ExecuteReader (CommandBehavior.CloseConnection)

興味深いことに、注目のコード行のうち、クエリは最後の2つだけで定義されます。LINQを使用すると、同じデータクエリを、以下に説明するような読みやすい色分けされた形式で、非常に短い時間で書き込むことができます。

Northwind db = new Northwind(@"C:\Data\Northwnd.mdf");
var query = from c in db.Customers select c;

LINQの利点

LINQには多くの利点がありますが、その中でも最も重要なのは、開発者が宣言的に表現できる強力な表現力です。LINQの他の利点のいくつかを以下に示します。

  • LINQは、設計時に間違いを見つけるのに役立つ構文の強調表示を提供します。

  • LINQはIntelliSenseを提供します。これは、より正確なクエリを簡単に作成できることを意味します。

  • LINQではコードの記述が非常に高速であるため、開発時間も大幅に短縮されます。

  • LINQは、C#言語に統合されているため、デバッグが容易です。

  • LINQは階層機能を備えているため、2つのテーブル間の関係を簡単に表示できます。これにより、複数のテーブルを結合するクエリを短時間で作成できます。

  • LINQを使用すると、単一のLINQ構文を使用しながら、さまざまなデータソースにクエリを実行できます。これは、主にその統合基盤によるものです。

  • LINQは拡張可能です。つまり、LINQの知識を使用して新しいデータソースタイプをクエリすることができます。

  • LINQは、単一のクエリで複数のデータソースを結合する機能と、複雑な問題をデバッグしやすい短いクエリのセットに分割する機能を提供します。

  • LINQは、SQLデータをXMLデータに変換するように、あるデータ型を別のデータ型に変換するための簡単な変換を提供します。

LINQプログラムを開始する前に、まずLINQ環境のセットアップの微妙な違いを理解することをお勧めします。LINQには、さまざまな種類のアプリケーションを使用するための革新的なプラットフォームである.NETフレームワークが必要です。LINQクエリは、C#またはVisualBasicのいずれかで簡単に記述できます。

Microsoftは、Visual Studioを使用して、これらの言語の両方、つまりC#とVisualBasic用のツールを提供しています。これらの例はすべてVisualStudio 2010でコンパイルおよび記述されています。ただし、Visual Basic2013エディションも使用できます。これは最新バージョンであり、Visual Studio2012と多くの類似点があります。

Visual Studio2010をWindows7にインストールする

Visual Studioは、DVDなどのインストールメディアからインストールできます。Visual Basic 2010をシステムに正常にインストールするには、管理者の資格情報が必要です。インストールする前に、すべてのリムーバブルUSBをシステムから切断することが重要です。そうしないと、インストールが失敗する可能性があります。インストールに不可欠なハードウェア要件のいくつかは次のとおりです。

ハードウェア要件

  • 1.6GHz以上
  • 1 GB RAM
  • 3GB(ハードディスクの空き容量)
  • 5400RPMハードディスクドライブ
  • DirectX9互換のビデオカード
  • DVD-ROMドライブ

インストール手順

Step 1 − Visual Studio 2010パッケージでDVDを挿入した後、最初にをクリックします Install or run program from your media 画面のポップアップボックスに表示されます。

Step 2−これで、VisualStudioのセットアップが画面に表示されます。選択Install Microsoft Visual Studio 2010

Step 3−クリックするとすぐにプロセスが開始され、セットアップウィンドウが画面に表示されます。しばらく時間がかかるインストールコンポーネントのロードが完了したら、をクリックします。Next ボタンをクリックして次のステップに進みます。

Step 4 −これはインストールの最後のステップであり、「ライセンス条項を読んで同意しました」を選択してクリックするだけのスタートページが表示されます。 Next ボタン。

Step 5−画面に表示されるオプションページからインストールする機能を選択します。あなたはどちらかを選ぶことができますFull または Customオプション。ディスク容量の要件に示されている必要なディスク容量よりも少ないディスク容量がある場合は、カスタムに進みます。

Step 6− [カスタム]オプションを選択すると、次のウィンドウが表示されます。インストールする機能を選択してクリックしますUpdate または、手順7に進みます。ただし、将来的にはカスタムオプションを使用しないことをお勧めします。選択した機能を使用しないようにする必要がある場合があります。

Step 7−すぐにポップアップウィンドウが表示され、インストールが開始されますが、時間がかかる場合があります。これはすべてのコンポーネントをインストールするためのものであることを忘れないでください。

Step 8−最後に、インストールが正常に完了したことを示すメッセージをウィンドウに表示できます。クリックFinish

Visual Studio 2010でLINQを使用してC#プログラムを作成する

  • Visual Studio 2010 Ultimateエディションを起動し、メニューから[ファイル]、[新しいプロジェクト]の順に選択します。

  • 新しいプロジェクトダイアログボックスが画面に表示されます。

  • 次に、インストールされているテンプレートの下のカテゴリとしてVisual C#を選択し、次に次の図に示すようにコンソールアプリケーションテンプレートを選択します。

  • 下部の名前ボックスにプロジェクトに名前を付けて、[OK]を押します。

  • 新しいプロジェクトは、画面の新しいダイアログボックスの右側にあるソリューションエクスプローラーに表示されます。

  • 次に、ソリューションエクスプローラーからProgram.csを選択すると、「usingSystem」で始まるエディターウィンドウでコードを表示できます。

  • ここで、次のC#プログラムのコーディングを開始できます。

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
			
namespace HelloWorld {
   class Program {
      static void Main(string[] args) {
      
         Console.WriteLine("Hello World")
         Console.ReadKey();
      } 		
   }
}
  • F5キーを押して、プロジェクトを実行します。を選択してプロジェクトを保存することを強くお勧めしますFileSave All プロジェクトを実行する前に。

Visual Studio2010でLINQを使用してVBプログラムを作成する

  • Visual Studio 2010 Ultimateエディションを起動し、メニューから[ファイル]、[新しいプロジェクト]の順に選択します。

  • 新しいプロジェクトダイアログボックスが画面に表示されます。

  • 次に、インストールされたテンプレートの下のカテゴリとしてVisual Basicを選択し、次にコンソールアプリケーションテンプレートを選択します。

  • 下部の名前ボックスにプロジェクトに名前を付けて、[OK]を押します。

  • Module1.vbの画面が表示されます。LINQを使用してここでVBコードの記述を開始します。

Module Module1

   Sub Main()
      Console.WriteLine("Hello World")
      Console.ReadLine()
   End Sub
   
End Module
  • F5キーを押して、プロジェクトを実行します。を選択してプロジェクトを保存することを強くお勧めしますFileSave All プロジェクトを実行する前に。

上記のC#またはVBのコードを暗号化して実行すると、次の結果が生成されます。

Hello World

クエリパターンを形成する拡張メソッドのセットは、LINQ標準クエリ演算子として知られています。LINQクエリ式の構成要素として、これらの演算子は、フィルタリング、並べ替え、射影、集計などのさまざまなクエリ機能を提供します。

LINQ標準クエリ演算子は、その機能に基づいて次のように分類できます。

  • フィルタリング演算子
  • オペレーターに参加する
  • 投影操作
  • ソート演算子
  • グループ化演算子
  • Conversions
  • Concatenation
  • Aggregation
  • 定量化操作
  • パーティション操作
  • 生成操作
  • セット操作
  • Equality
  • 要素演算子

フィルタリング演算子

フィルタリングは、特定の条件を満たす要素のみが選択されるように結果セットを制限する操作です。

例を表示

オペレーター 説明 C#クエリ式の構文 VBクエリ式の構文
どこ 述語関数に基づいて値をフィルタリングする どこ どこ
OfType 指定されたタイプとしての能力に基づいて値をフィルタリングします 適用できません 適用できません

オペレーターに参加する

結合とは、直接的な関係をたどることが難しいデータソースを対象とする操作を指します。

例を表示

オペレーター 説明 C#クエリ式の構文 VBクエリ式の構文
参加する オペレーターは、一致するキーに基づいて2つのシーケンスを結合します 参加する…で…で…等しい… x In…、yIn…からxa = ya
GroupJoin 2つのシーケンスを結合し、一致する要素をグループ化します 参加する…で…に…等しい…に… グループ参加…で…で…

投影操作

投影は、オブジェクトが特定のプロパティのみを持つまったく新しい形式に変換される操作です。

例を表示

オペレーター 説明 C#クエリ式の構文 VBクエリ式の構文
選択する 演算子は、変換関数に基づいて値を投影します 選択する 選択する
SelectMany 演算子は、変換関数に基づく値のシーケンスを投影し、それらを単一のシーケンスに平坦化します 複数のfrom句を使用する 複数のFrom句を使用する

ソート演算子

並べ替え操作では、1つ以上の属性に基づいてシーケンスの要素を並べ替えることができます。

例を表示

オペレーター 説明 C#クエリ式の構文 VBクエリ式の構文
OrderBy 演算子は値を昇順でソートします orderby 注文者
OrderByDescending 演算子は値を降順でソートします orderby ...降順 並べ替え...降順
ThenBy 昇順で2次ソートを実行します orderby…、… 注文者…、…
ThenByDescending 降順で二次ソートを実行します orderby…、…降順 並べ替え…、…降順
逆行する コレクション内の要素の順序を逆にします 適用できません 適用できません

グループ化演算子

オペレーターは、共通の共有属性に基づいてデータをいくつかのグループに入れます。

例を表示

オペレーター 説明 C#クエリ式の構文 VBクエリ式の構文
GroupBy アイテムのシーケンスをグループに編成し、タイプIGrouping <key、element>のIEnumerableコレクションとして返します。 group…by-or-group…by…into… Group…By…Into…
見上げる キーペアのシーケンスが返されるグループ化操作を実行します 適用できません 適用できません

変換

演算子は入力オブジェクトのタイプを変更し、さまざまなアプリケーションで使用されます。

例を表示

オペレーター 説明 C#クエリ式の構文 VBクエリ式の構文
AsEnumerable IEnumerable <T>として入力された入力を返します 適用できません 適用できません
AsQueryable (ジェネリック)IEnumerableは(ジェネリック)IQueryableに変換されます 適用できません 適用できません
キャスト コレクションの要素を指定されたタイプにキャストします 明示的に型指定された範囲変数を使用します。例:単語の文字列strから から…として…
OfType 特定のタイプにキャストする機能に応じて、値に基づいて値をフィルタリングします 適用できません 適用できません
ToArray クエリの実行を強制し、コレクションを配列に変換します 適用できません 適用できません
ToDictionary キーセレクター関数に基づいて、要素をDictionary <TKey、TValue>に設定し、LINQクエリの実行を強制します 適用できません 適用できません
ToList コレクションをList <T>に変換することにより、クエリの実行を強制します 適用できません 適用できません
見上げる キーセレクター関数に基づいて、クエリの実行を強制し、要素をLookup <TKey、TElement>に配置します 適用できません 適用できません

連結

2つのシーケンスの連結を実行し、重複を削除しないという事実を除いて、操作の点でUnion演算子と非常に似ています。

例を表示

オペレーター 説明 C#クエリ式の構文 VBクエリ式の構文
コンキャット 2つのシーケンスが連結されて、1つのシーケンスが形成されます。 適用できません 適用できません

集約

任意のタイプの目的の集計を実行し、LINQでカスタム集計を作成できるようにします。

例を表示

オペレーター 説明 C#クエリ式の構文 VBクエリ式の構文
集計 コレクションの値を操作して、カスタム集計操作を実行します 適用できません 適用できません
平均 値のコレクションの平均値が計算されます 適用できません Aggregate…In…IntoAverage()
カウント コレクション内の述語関数を満たす要素をカウントします 適用できません Aggregate…In…IntoCount()
LonCount 膨大なコレクション内の述語関数を満たす要素をカウントします 適用できません 集約…In…IntoLongCount()
マックス コレクション内の最大値を見つける 適用できません 集約…In…IntoMax()
最小 コレクション内に存在する最小値を見つける 適用できません 集約…In…IntoMin()
コレクション内の値の合計を調べる 適用できません Aggregate…In…IntoSum()

定量化操作

これらの演算子は、シーケンス内の一部またはすべての要素が特定の条件を満たす場合に、ブール値、つまりTrueまたはFalseを返します。

例を表示

オペレーター 説明 C#クエリ式の構文 VBクエリ式の構文
すべて シーケンスのすべての要素が述語条件を満たす場合、値「True」を返します 適用できません 集約…で…すべてに(…)
どれか シーケンスを検索して、同じ要素のいずれかが指定された条件を満たすかどうかを判断します 適用できません Aggregate…In…IntoAny()
含まれています シーケンスに特定の要素が含まれていない場合に特定の要素がシーケンスに存在することが判明した場合は「True」値を返し、「false」値を返します。 適用できません 適用できません

パーティション演算子

シーケンスの要素を再配置してから1つを返すことなく、入力シーケンスを2つの別々のセクションに分割します。

例を表示

オペレーター 説明 C#クエリ式の構文 VBクエリ式の構文
スキップ シーケンス内の指定された数の要素をスキップし、残りの要素を返します 適用できません スキップ
SkipWhile スキップする要素の数がブール条件で指定されることを除いて、スキップの場合と同じです。 適用できません スキップする
取る シーケンスから指定された数の要素を取得し、残りの要素をスキップします 適用できません 取る
TakeWhile 取得する要素の数がブール条件で指定されることを除いて、Takeの場合と同じです。 適用できません しばらくお待ちください

生成操作

値の新しいシーケンスは、世代演算子によって作成されます。

例を表示

オペレーター 説明 C#クエリ式の構文 VBクエリ式の構文
DefaultIfEmpty 空のシーケンスに適用する場合、シーケンス内にデフォルト要素を生成します 適用できません 適用できません
空の 空の値のシーケンスを返し、最も単純な世代演算子です 適用できません 適用できません
範囲 整数または数値のシーケンスを持つコレクションを生成します 適用できません 適用できません
繰り返す 特定の長さの繰り返し値を含むシーケンスを生成します 適用できません 適用できません

セット操作

セット操作には4つの演算子があり、それぞれが異なる基準に基づいて結果を生成します。

例を表示

オペレーター 説明 C#クエリ式の構文 VBクエリ式の構文
明確な 重複データがある場合はそれをフィルタリングして、コレクションから一意の値のリストを作成します 適用できません 明確な
を除いて 2つのコレクションの値を比較し、一方のコレクションからもう一方のコレクションにないものを返します 適用できません 適用できません
交差する 2つの別々のコレクションで同一であることが判明した値のセットを返します 適用できません 適用できません
連合 2つの異なるコレクションのコンテンツを1つのリストに結合し、重複するコンテンツもありません 適用できません 適用できません

平等

2つの文(列挙可能)を比較し、それらが完全に一致するかどうかを判断します。

例を表示

オペレーター 説明 C#クエリ式の構文 VBクエリ式の構文
SequenceEqual 2つのシーケンスが互いに同一であることが判明した場合、ブール値が生成されます 適用できません 適用できません

要素演算子

DefaultIfEmptyを除いて、残りの8つの標準クエリ要素演算子はすべて、コレクションから1つの要素を返します。

例を表示

オペレーター 説明 C#クエリ式の構文 VBクエリ式の構文
ElementAt コレクション内の特定のインデックス内に存在する要素を返します 適用できません 適用できません
ElementAtOrDefault ElementAtと同じですが、特定のインデックスが範囲外の場合にデフォルト値を返す点が異なります。 適用できません 適用できません
最初 コレクション内の最初の要素、または特定の条件を満たす最初の要素を取得します 適用できません 適用できません
FirstOrDefault そのような要素が存在しない場合にデフォルト値も返すという事実を除いて、Firstと同じです 適用できません 適用できません
最終 コレクションに存在する最後の要素、または特定の条件を満たす最後の要素を取得します 適用できません 適用できません
LastOrDefault そのような要素が存在しない場合にデフォルト値も返すという事実を除いて、Lastと同じです 適用できません 適用できません
シングル コレクションのlone要素または特定の条件を満たすlone要素を返します 適用できません 適用できません
SingleOrDefault そのような孤独な要素が存在しない場合にデフォルト値も返すことを除いて、Singleと同じです 適用できません 適用できません
DefaultIfEmpty コレクションまたはリストが空またはnullの場合、デフォルト値を返します 適用できません 適用できません

LINQ to SQLは、リレーショナルデータをオブジェクトとして管理するためのインフラストラクチャ(ランタイム)を提供します。これは、.NET Frameworkのバージョン3.5のコンポーネントであり、オブジェクトモデルの言語統合クエリのSQLへの変換を適切に実行します。これらのクエリは、実行のためにデータベースに送信されます。データベースから結果を取得した後、LINQ toSQLは再び結果をオブジェクトに変換します。

SQLへのLINQの導入

ほとんどのASP.NET開発者にとって、LINQ to SQL(DLINQとも呼ばれます)は、通常のLINQ式を使用してSQLサーバーデータベース内のデータをクエリできるため、統合言語クエリの魅力的な部分です。また、データの更新、削除、挿入も可能ですが、問題となる唯一の欠点は、SQLサーバーデータベースへの制限です。ただし、複雑さの軽減、コーディングの数行など、ADO.NETよりもLINQ toSQLには多くの利点があります。

以下は、LINQ toSQLの実行アーキテクチャを示す図です。

LINQ to SQLを使用する方法は?

Step 1−データベースサーバーとの新しい「データ接続」を作成します。表示&arrar; サーバーエクスプローラー&arrar; データ接続&arrar; 接続を追加

Step 2 −LINQをSQLクラスファイルに追加する

Step 3 −データベースからテーブルを選択し、新しいLINQ toSQLクラスファイルにドラッグアンドドロップします。

Step 4 −クラスファイルにテーブルを追加しました。

LINQ toSQLを使用したクエリ

LINQ to SQLを使用してクエリを実行するためのルールは、標準のLINQクエリのルールと似ています。つまり、クエリは遅延または即時に実行されます。LINQ to SQLを使用したクエリの実行で役割を果たすさまざまなコンポーネントがあり、これらは次のコンポーネントです。

  • LINQ to SQL API −アプリケーションに代わってクエリの実行を要求し、それをLINQ to SQLProviderに送信します。

  • LINQ to SQL Provider −クエリをTransact SQL(T-SQL)に変換し、実行のために新しいクエリをADOプロバイダーに送信します。

  • ADO Provider −クエリの実行後、結果をDataReaderの形式でLINQ to SQL Providerに送信し、次にそれをユーザーオブジェクトの形式に変換します。

LINQ to SQLクエリを実行する前に、DataContextクラスを介してデータソースに接続することが重要であることに注意してください。

LINQ To SQLを使用した挿入、更新、および削除

追加または挿入

C#

using System;
using System.Linq;

namespace LINQtoSQL {
   class LinqToSQLCRUD {
      static void Main(string[] args) {
      
         string connectString = System.Configuration.ConfigurationManager.ConnectionStrings["LinqToSQLDBConnectionString"].ToString();

         LinqToSQLDataContext db = new LinqToSQLDataContext(connectString);           

         //Create new Employee
		 
         Employee newEmployee = new Employee();
         newEmployee.Name = "Michael";
         newEmployee.Email = "[email protected]";
         newEmployee.ContactNo = "343434343";
         newEmployee.DepartmentId = 3;
         newEmployee.Address = "Michael - USA";

         //Add new Employee to database
         db.Employees.InsertOnSubmit(newEmployee);

         //Save changes to Database.
         db.SubmitChanges();

         //Get new Inserted Employee            
         Employee insertedEmployee = db.Employees.FirstOrDefault(e ⇒e.Name.Equals("Michael"));

         Console.WriteLine("Employee Id = {0} , Name = {1}, Email = {2}, ContactNo = {3}, Address = {4}",
                          insertedEmployee.EmployeeId, insertedEmployee.Name, insertedEmployee.Email, 
                          insertedEmployee.ContactNo, insertedEmployee.Address);

         Console.WriteLine("\nPress any key to continue.");
         Console.ReadKey();
      }
   }
}

VB

Module Module1

   Sub Main()
   
      Dim connectString As String = System.Configuration.ConfigurationManager.ConnectionStrings("LinqToSQLDBConnectionString").ToString()

      Dim db As New LinqToSQLDataContext(connectString)

      Dim newEmployee As New Employee()
	  
      newEmployee.Name = "Michael"
      newEmployee.Email = "[email protected]"
      newEmployee.ContactNo = "343434343"
      newEmployee.DepartmentId = 3
      newEmployee.Address = "Michael - USA"
     
      db.Employees.InsertOnSubmit(newEmployee)
     
      db.SubmitChanges()
     
      Dim insertedEmployee As Employee = db.Employees.FirstOrDefault(Function(e) e.Name.Equals("Michael"))

      Console.WriteLine("Employee Id = {0} , Name = {1}, Email = {2}, ContactNo = {3}, 
         Address = {4}", insertedEmployee.EmployeeId, insertedEmployee.Name,
         insertedEmployee.Email, insertedEmployee.ContactNo, insertedEmployee.Address)

      Console.WriteLine(vbLf & "Press any key to continue.")
      Console.ReadKey()
	 
   End Sub
  
End Module

上記のC#またはVBのコードをコンパイルして実行すると、次の結果が生成されます。

Emplyee ID = 4, Name = Michael, Email = [email protected], ContactNo = 
343434343, Address = Michael - USA

Press any key to continue.

更新

C#

using System;
using System.Linq;

namespace LINQtoSQL {
   class LinqToSQLCRUD {
      static void Main(string[] args) {
      
         string connectString = System.Configuration.ConfigurationManager.ConnectionStrings["LinqToSQLDBConnectionString"].ToString();

         LinqToSQLDataContext db = new LinqToSQLDataContext(connectString);

         //Get Employee for update
         Employee employee = db.Employees.FirstOrDefault(e =>e.Name.Equals("Michael"));

         employee.Name = "George Michael";
         employee.Email = "[email protected]";
         employee.ContactNo = "99999999";
         employee.DepartmentId = 2;
         employee.Address = "Michael George - UK";

         //Save changes to Database.
         db.SubmitChanges();

         //Get Updated Employee            
         Employee updatedEmployee = db.Employees.FirstOrDefault(e ⇒e.Name.Equals("George Michael"));

         Console.WriteLine("Employee Id = {0} , Name = {1}, Email = {2}, ContactNo = {3}, Address = {4}",
                          updatedEmployee.EmployeeId, updatedEmployee.Name, updatedEmployee.Email, 
                          updatedEmployee.ContactNo, updatedEmployee.Address);

         Console.WriteLine("\nPress any key to continue.");
         Console.ReadKey();
      }
   }
}

VB

Module Module1

   Sub Main()
  
      Dim connectString As String = System.Configuration.ConfigurationManager.ConnectionStrings("LinqToSQLDBConnectionString").ToString()

      Dim db As New LinqToSQLDataContext(connectString)

      Dim employee As Employee = db.Employees.FirstOrDefault(Function(e) e.Name.Equals("Michael"))

      employee.Name = "George Michael"
      employee.Email = "[email protected]"
      employee.ContactNo = "99999999"
      employee.DepartmentId = 2
      employee.Address = "Michael George - UK"

      db.SubmitChanges()
          
      Dim updatedEmployee As Employee = db.Employees.FirstOrDefault(Function(e) e.Name.Equals("George Michael"))

      Console.WriteLine("Employee Id = {0} , Name = {1}, Email = {2}, ContactNo = {3},
         Address = {4}", updatedEmployee.EmployeeId, updatedEmployee.Name, 
         updatedEmployee.Email, updatedEmployee.ContactNo, updatedEmployee.Address)

      Console.WriteLine(vbLf & "Press any key to continue.")
      Console.ReadKey()
	  
   End Sub
   
End Module

上記のC#またはVbのコードをコンパイルして実行すると、次の結果が生成されます。

Emplyee ID = 4, Name = George Michael, Email = [email protected], ContactNo = 
999999999, Address = Michael George - UK

Press any key to continue.

削除

C#

using System;
using System.Linq;

namespace LINQtoSQL {
   class LinqToSQLCRUD {
      static void Main(string[] args) {
      
         string connectString = System.Configuration.ConfigurationManager.ConnectionStrings["LinqToSQLDBConnectionString"].ToString();

         LinqToSQLDataContext db = newLinqToSQLDataContext(connectString);

         //Get Employee to Delete
         Employee deleteEmployee = db.Employees.FirstOrDefault(e ⇒e.Name.Equals("George Michael"));

         //Delete Employee
         db.Employees.DeleteOnSubmit(deleteEmployee);

         //Save changes to Database.
         db.SubmitChanges();

         //Get All Employee from Database
         var employeeList = db.Employees;
         foreach (Employee employee in employeeList) {
            Console.WriteLine("Employee Id = {0} , Name = {1}, Email = {2}, ContactNo = {3}",
               employee.EmployeeId, employee.Name, employee.Email, employee.ContactNo);
         }            

         Console.WriteLine("\nPress any key to continue.");
         Console.ReadKey();
      }
   }
}

VB

Module Module1

   Sub Main()
   
      Dim connectString As String = System.Configuration.ConfigurationManager.ConnectionStrings("LinqToSQLDBConnectionString").ToString()

      Dim db As New LinqToSQLDataContext(connectString)

      Dim deleteEmployee As Employee = db.Employees.FirstOrDefault(Function(e) e.Name.Equals("George Michael"))

      db.Employees.DeleteOnSubmit(deleteEmployee)

      db.SubmitChanges()

      Dim employeeList = db.Employees
	  
      For Each employee As Employee In employeeList
         Console.WriteLine("Employee Id = {0} , Name = {1}, Email = {2}, ContactNo = {3}",
            employee.EmployeeId, employee.Name, employee.Email, employee.ContactNo)
      Next 

      Console.WriteLine(vbLf & "Press any key to continue.")
      Console.ReadKey()
   End Sub
   
End Module

上記のC#またはVBのコードをコンパイルして実行すると、次の結果が生成されます。

Emplyee ID = 1, Name = William, Email = [email protected], ContactNo = 999999999
Emplyee ID = 2, Name = Miley, Email = [email protected], ContactNo = 999999999
Emplyee ID = 3, Name = Benjamin, Email = [email protected], ContactNo = 

Press any key to continue.

LINQ to Objectsは、LINQ toSQLまたはLINQto XMLの場合のように、LINQプロバイダー(API)を必要とせずに、メモリ内のデータコレクションにアクセスするためのIEnumerable <T>をサポートするLINQクエリの使用法を提供します。

オブジェクトへのLINQの導入

LINQ to Objectsのクエリは、通常IEnumerable <T>タイプの変数のみを返します。要するに、LINQ to Objectsは以前と同じようにコレクションに新しいアプローチを提供します。コレクションからデータを取得するために長いコーディング(非常に複雑なforeachループ)を作成することが不可欠でしたが、現在は目的のデータを明確に説明する宣言コードを作成することに置き換えられています。取得するために必要です。

LINQ to Objectsには、読みやすさの向上、強力なフィルタリング、グループ化の機能、最小限のアプリケーションコーディングによる強化された順序付けなど、従来のforeachループに比べて多くの利点があります。このようなLINQクエリは、本質的にコンパクトであり、変更を加えることなく、または少し変更するだけで、他のデータソースに移植できます。

以下は、オブジェクトへの単純なLINQの例です-

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;

namespace LINQtoObjects {
   class Program {
      static void Main(string[] args) {
      
         string[] tools = { "Tablesaw", "Bandsaw", "Planer", "Jointer", "Drill", "Sander" };
         var list = from t in tools select t;

         StringBuilder sb = new StringBuilder();

         foreach (string s in list) {
            sb.Append(s + Environment.NewLine);
         }
		 
         Console.WriteLine(sb.ToString(), "Tools");
         Console.ReadLine();
      }
   }
}

この例では、文字列の配列(ツール)が、LINQ toObjectsを使用してクエリされるオブジェクトのコレクションとして使用されています。

Objects query is:
var list = from t in tools select t;

上記のコードをコンパイルして実行すると、次の結果が得られます。

Tablesaw
Bandsaw
Planer
Jointer
Drill
Sander

オブジェクトへのLINQを使用したメモリコレクションでのクエリ

C#

using System;
using System.Collections.Generic;
using System.Linq;

namespace LINQtoObjects {
   class Department {
      public int DepartmentId { get; set; }
      public string Name { get; set; }
   }

   class LinqToObjects {
      static void Main(string[] args) {
      
         List<Department> departments = new List<Department>();
			
         departments.Add(new Department { DepartmentId = 1, Name = "Account" });
         departments.Add(new Department { DepartmentId = 2, Name = "Sales" });
         departments.Add(new Department { DepartmentId = 3, Name = "Marketing" });

         var departmentList = from d in departments
                              select d;

         foreach (var dept in departmentList) {
            Console.WriteLine("Department Id = {0} , Department Name = {1}",
               dept.DepartmentId, dept.Name);
         }
		 
         Console.WriteLine("\nPress any key to continue.");
         Console.ReadKey();
      }
   }
}

VB

Imports System.Collections.Generic
Imports System.Linq

Module Module1

   Sub Main(ByVal args As String())

      Dim account As New Department With {.Name = "Account", .DepartmentId = 1}
      Dim sales As New Department With {.Name = "Sales", .DepartmentId = 2}
      Dim marketing As New Department With {.Name = "Marketing", .DepartmentId = 3}

      Dim departments As New System.Collections.Generic.List(Of Department)(New Department() {account, sales, marketing})

      Dim departmentList = From d In departments

      For Each dept In departmentList
         Console.WriteLine("Department Id = {0} , Department Name = {1}", dept.DepartmentId, dept.Name)
      Next

      Console.WriteLine(vbLf & "Press any key to continue.")
      Console.ReadKey()
   End Sub

   Class Department
      Public Property Name As String
      Public Property DepartmentId As Integer
   End Class
   
End Module

上記のC#またはVBのコードをコンパイルして実行すると、次の結果が得られます。

Department Id = 1, Department Name = Account
Department Id = 2, Department Name = Sales
Department Id = 3, Department Name = Marketing

Press any key to continue.

データセットは、メモリ内で非常に便利なデータ表現を提供し、さまざまなデータベースのアプリケーションに使用されます。LINQ toADO.NETのテクノロジの1つであるLINQto Datasetは、データセットのデータに対するクエリの実行を手間をかけずに容易にし、生産性を向上させます。

データセットへのLINQの導入

LINQ to Datasetにより、開発者はクエリを簡単に実行できるようになりました。特定のクエリ言語でクエリを作成する必要はありません。代わりに、プログラミング言語で同じものを作成できます。LINQ to Datasetは、データが複数のデータソースから統合されている場所のクエリにも使用できます。また、メモリ内のコレクションからデータにアクセスするために、LINQ toSQLやLINQtoXMLのようなLINQプロバイダーも必要ありません。

以下は、LINQ to Datasetクエリの簡単な例です。このクエリでは、最初にデータソースが取得され、次にデータセットに2つのデータテーブルが入力されます。両方のテーブル間に関係が確立され、join句を使用して両方のテーブルに対してLINQクエリが作成されます。最後に、foreachループを使用して目的の結果を表示します。

C#

using System;
using System.Collections.Generic;
using System.Data;
using System.Data.SqlClient;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

namespace LINQtoDataset {
   class Program {
      static void Main(string[] args) {
      
         string connectString = System.Configuration.ConfigurationManager.ConnectionStrings["LinqToSQLDBConnectionString"].ToString();

         string sqlSelect = "SELECT * FROM Department;" + "SELECT * FROM Employee;";

         // Create the data adapter to retrieve data from the database
         SqlDataAdapter da = new SqlDataAdapter(sqlSelect, connectString);
        
         // Create table mappings
         da.TableMappings.Add("Table", "Department");
         da.TableMappings.Add("Table1", "Employee");

         // Create and fill the DataSet
         DataSet ds = new DataSet();
         da.Fill(ds);

         DataRelation dr = ds.Relations.Add("FK_Employee_Department",
                           ds.Tables["Department"].Columns["DepartmentId"],
                           ds.Tables["Employee"].Columns["DepartmentId"]);

         DataTable department = ds.Tables["Department"];
         DataTable employee = ds.Tables["Employee"];

         var query = from d in department.AsEnumerable()
                     join e in employee.AsEnumerable()
                     on d.Field<int>("DepartmentId") equals
                     e.Field<int>("DepartmentId")                        
                     select new {
                        EmployeeId = e.Field<int>("EmployeeId"),
                        Name = e.Field<string>("Name"),                            
                        DepartmentId = d.Field<int>("DepartmentId"),                            
                        DepartmentName = d.Field<string>("Name")
                     };

         foreach (var q in query) {
            Console.WriteLine("Employee Id = {0} , Name = {1} , Department Name = {2}",
               q.EmployeeId, q.Name, q.DepartmentName);
         }

         Console.WriteLine("\nPress any key to continue.");
         Console.ReadKey();
      }
   }
}

VB

Imports System.Data.SqlClient
Imports System.Linq

Module LinqToDataSet

   Sub Main()
   
      Dim connectString As String = System.Configuration.ConfigurationManager.ConnectionStrings("LinqToSQLDBConnectionString").ToString()

      Dim sqlSelect As String = "SELECT * FROM Department;" + "SELECT * FROM Employee;"
      Dim sqlCnn As SqlConnection = New SqlConnection(connectString)
      sqlCnn.Open()

      Dim da As New SqlDataAdapter
      da.SelectCommand = New SqlCommand(sqlSelect, sqlCnn)

      da.TableMappings.Add("Table", "Department")
      da.TableMappings.Add("Table1", "Employee")

      Dim ds As New DataSet()
      da.Fill(ds)

      Dim dr As DataRelation = ds.Relations.Add("FK_Employee_Department", ds.Tables("Department").Columns("DepartmentId"), ds.Tables("Employee").Columns("DepartmentId"))

      Dim department As DataTable = ds.Tables("Department")
      Dim employee As DataTable = ds.Tables("Employee")

      Dim query = From d In department.AsEnumerable()
                  Join e In employee.AsEnumerable() On d.Field(Of Integer)("DepartmentId") Equals
                  e.Field(Of Integer)("DepartmentId")
                  Select New Person With { _
                        .EmployeeId = e.Field(Of Integer)("EmployeeId"),
                        .EmployeeName = e.Field(Of String)("Name"),
                        .DepartmentId = d.Field(Of Integer)("DepartmentId"),
                        .DepartmentName = d.Field(Of String)("Name")
                  }

      For Each e In query
         Console.WriteLine("Employee Id = {0} , Name = {1} , Department Name = {2}", e.EmployeeId, e.EmployeeName, e.DepartmentName)
      Next

      Console.WriteLine(vbLf & "Press any key to continue.")
      Console.ReadKey()
	  
   End Sub
  
   Class Person
      Public Property EmployeeId As Integer
      Public Property EmployeeName As String
      Public Property DepartmentId As Integer
      Public Property DepartmentName As String
   End Class
   
End Module

上記のC#またはVBのコードをコンパイルして実行すると、次の結果が得られます。

Employee Id = 1, Name = William, Department Name = Account
Employee Id = 2, Name = Benjamin, Department Name = Account
Employee Id = 3, Name = Miley, Department Name = Sales

Press any key to continue.

LinQ toDatasetを使用したデータセットのクエリ

LINQ to Datasetを使用してデータセットのクエリを開始する前に、データをデータセットにロードすることが重要です。これは、DataAdapterクラスを使用するか、LINQ toSQLを使用して実行されます。LINQ to Datasetを使用したクエリの作成は、他のLINQ対応データソースと一緒にLINQを使用してクエリを作成するのと非常によく似ています。

単一テーブルクエリ

次の単一テーブルクエリでは、すべてのオンライン注文がSalesOrderHeaderTtableから収集され、注文ID、注文日、注文番号が出力として表示されます。

C#

using System;
using System.Collections.Generic;
using System.Data;
using System.Data.SqlClient;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

namespace LinqToDataset {
   class SingleTable {
      static void Main(string[] args) {
      
         string connectString = System.Configuration.ConfigurationManager.ConnectionStrings["LinqToSQLDBConnectionString"].ToString();

         string sqlSelect = "SELECT * FROM Department;";

         // Create the data adapter to retrieve data from the database
         SqlDataAdapter da = new SqlDataAdapter(sqlSelect, connectString);

         // Create table mappings
         da.TableMappings.Add("Table", "Department");           

         // Create and fill the DataSet
         DataSet ds = new DataSet();
         da.Fill(ds);

         DataTable department = ds.Tables["Department"];            

         var query = from d in department.AsEnumerable()                        
         select new {
            DepartmentId = d.Field<int>("DepartmentId"),
            DepartmentName = d.Field<string>("Name")
         };

         foreach (var q in query) {
            Console.WriteLine("Department Id = {0} , Name = {1}",
               q.DepartmentId, q.DepartmentName);
         }

         Console.WriteLine("\nPress any key to continue.");
         Console.ReadKey();
      }
   }
}

VB

Imports System.Data.SqlClient
Imports System.Linq

Module LinqToDataSet

   Sub Main()
   
      Dim connectString As String = System.Configuration.ConfigurationManager.ConnectionStrings("LinqToSQLDBConnectionString").ToString()

      Dim sqlSelect As String = "SELECT * FROM Department;"
      Dim sqlCnn As SqlConnection = New SqlConnection(connectString)
      sqlCnn.Open()

      Dim da As New SqlDataAdapter
      da.SelectCommand = New SqlCommand(sqlSelect, sqlCnn)

      da.TableMappings.Add("Table", "Department")
      Dim ds As New DataSet()
      da.Fill(ds)

      Dim department As DataTable = ds.Tables("Department")

      Dim query = From d In department.AsEnumerable()
      Select New DepartmentDetail With {
         .DepartmentId = d.Field(Of Integer)("DepartmentId"),
            .DepartmentName = d.Field(Of String)("Name")
      }

      For Each e In query
         Console.WriteLine("Department Id = {0} , Name = {1}", e.DepartmentId, e.DepartmentName)
      Next

      Console.WriteLine(vbLf & "Press any key to continue.")
      Console.ReadKey()
   End Sub

   Public Class DepartmentDetail
      Public Property DepartmentId As Integer
      Public Property DepartmentName As String
   End Class
   
End Module

上記のC#またはVBのコードをコンパイルして実行すると、次の結果が得られます。

Department Id = 1, Name = Account
Department Id = 2, Name = Sales
Department Id = 3, Name = Pre-Sales
Department Id = 4, Name = Marketing

Press any key to continue.

LINQ to XMLは、標準のクエリ演算子、プログラミングインターフェイスなど、すべてのLINQ機能に簡単にアクセスできます。LINQtoXMLは、.NETフレームワークに統合されており、デバッグ、コンパイル時チェック、厳密な型指定などの.NETフレームワーク機能も最大限に活用します。そして言うべきより多く。

XMLへのLINQの導入

LINQ to XMLを使用している間、XMLドキュメントをメモリにロードするのは簡単で、クエリとドキュメントの変更がより簡単です。メモリに存在するXMLドキュメントをディスクに保存してシリアル化することもできます。これにより、開発者はやや複雑なXMLクエリ言語を学ぶ必要がなくなります。

LINQ to XMLは、System.Xml.Linq名前空間にその力があります。これには、XMLを操作するために必要な19のクラスがすべて含まれています。これらのクラスは次のクラスです。

  • XAttribute
  • XCData
  • XComment
  • XContainer
  • XDeclaration
  • XDocument
  • XDocumentType
  • XElement
  • XName
  • XNamespace
  • XNode
  • XNodeDocumentOrderComparer
  • XNodeEqualityComparer
  • XObject
  • XObjectChange
  • XObjectChangeEventArgs
  • XObjectEventHandler
  • XProcessingInstruction
  • XText

LINQを使用してXMLファイルを読み取る

C#

using System;
using System.Collections.Generic;
using System.Linq;
using System.Xml.Linq;

namespace LINQtoXML {
   class ExampleOfXML {
      static void Main(string[] args) {
      
         string myXML = @"<Departments>
                       <Department>Account</Department>
                       <Department>Sales</Department>
                       <Department>Pre-Sales</Department>
                       <Department>Marketing</Department>
                       </Departments>";

         XDocument xdoc = new XDocument();
         xdoc = XDocument.Parse(myXML);

         var result = xdoc.Element("Departments").Descendants();

         foreach (XElement item in result) {
            Console.WriteLine("Department Name - " + item.Value);
         }

         Console.WriteLine("\nPress any key to continue.");
         Console.ReadKey();
      }
   }
}

VB

Imports System.Collections.Generic
Imports System.Linq
Imports System.Xml.Linq

Module Module1

   Sub Main(ByVal args As String())
   
      Dim myXML As String = "<Departments>" & vbCr & vbLf & 
                           "<Department>Account</Department>" & vbCr & vbLf & 
                           "<Department>Sales</Department>" & vbCr & vbLf & 
                           "<Department>Pre-Sales</Department>" & vbCr & vbLf & 
                           "<Department>Marketing</Department>" & vbCr & vbLf & 
                           "</Departments>"

      Dim xdoc As New XDocument()
      xdoc = XDocument.Parse(myXML)

      Dim result = xdoc.Element("Departments").Descendants()

      For Each item As XElement In result
         Console.WriteLine("Department Name - " + item.Value)
      Next

      Console.WriteLine(vbLf & "Press any key to continue.")
      Console.ReadKey()
	  
   End Sub
   
End Module

上記のC#またはVBのコードをコンパイルして実行すると、次の結果が得られます。

Department Name - Account
Department Name - Sales
Department Name - Pre-Sales
Department Name - Marketing

Press any key to continue.

新しいノードを追加

C#

using System;
using System.Collections.Generic;
using System.Linq;
using System.Xml.Linq;

namespace LINQtoXML {
   class ExampleOfXML {
      static void Main(string[] args) {
      
         string myXML = @"<Departments>
                       <Department>Account</Department>
                       <Department>Sales</Department>
                       <Department>Pre-Sales</Department>
                       <Department>Marketing</Department>
                       </Departments>";

         XDocument xdoc = new XDocument();
         xdoc = XDocument.Parse(myXML);

         //Add new Element
         xdoc.Element("Departments").Add(new XElement("Department", "Finance"));

         //Add new Element at First
         xdoc.Element("Departments").AddFirst(new XElement("Department", "Support"));

         var result = xdoc.Element("Departments").Descendants();

         foreach (XElement item in result) {
            Console.WriteLine("Department Name - " + item.Value);
         }

         Console.WriteLine("\nPress any key to continue.");
         Console.ReadKey();
      }
   }
}

VB

Imports System.Collections.Generic
Imports System.Linq
Imports System.Xml.Linq

Module Module1

   Sub Main(ByVal args As String())
   
      Dim myXML As String = "<Departments>" & vbCr & vbLf & 
     	                   "<Department>Account</Department>" & vbCr & vbLf & 
     	                   "<Department>Sales</Department>" & vbCr & vbLf & 
     	                   "<Department>Pre-Sales</Department>" & vbCr & vbLf & 
     	                   "<Department>Marketing</Department>" & vbCr & vbLf & 
     	                   "</Departments>"

      Dim xdoc As New XDocument()
      xdoc = XDocument.Parse(myXML)

      xdoc.Element("Departments").Add(New XElement("Department", "Finance"))
     
      xdoc.Element("Departments").AddFirst(New XElement("Department", "Support"))

      Dim result = xdoc.Element("Departments").Descendants()

      For Each item As XElement In result
         Console.WriteLine("Department Name - " + item.Value)
      Next

      Console.WriteLine(vbLf & "Press any key to continue.")
      Console.ReadKey()
	  
   End Sub
   
End Module

上記のC#またはVBのコードをコンパイルして実行すると、次の結果が得られます。

Department Name - Support
Department Name - Account
Department Name - Sales
Department Name - Pre-Sales
Department Name - Marketing
Department Name - Finance

Press any key to continue.

特定のノードを削除する

C#

using System;
using System.Collections.Generic;
using System.Linq;
using System.Xml.Linq;

namespace LINQtoXML {
   class ExampleOfXML {
      static void Main(string[] args) {
      
         string myXML = @"<Departments>
                       <Department>Support</Department>
                       <Department>Account</Department>
                       <Department>Sales</Department>
                       <Department>Pre-Sales</Department>
                       <Department>Marketing</Department>
                       <Department>Finance</Department>
                       </Departments>";

         XDocument xdoc = new XDocument();
         xdoc = XDocument.Parse(myXML);

         //Remove Sales Department
         xdoc.Descendants().Where(s =>s.Value == "Sales").Remove(); 

         var result = xdoc.Element("Departments").Descendants();

         foreach (XElement item in result) {
            Console.WriteLine("Department Name - " + item.Value);
         }

         Console.WriteLine("\nPress any key to continue.");
         Console.ReadKey();
      }
   }
}

VB

Imports System.Collections.Generic
Imports System.Linq
Imports System.Xml.Linq

Module Module1

   Sub Main(args As String())
   
      Dim myXML As String = "<Departments>" & vbCr & vbLf & 
     	                   "<Department>Support</Department>" & vbCr & vbLf & 
     	                   "<Department>Account</Department>" & vbCr & vbLf & 
     	                   "<Department>Sales</Department>" & vbCr & vbLf & 
     	                   "<Department>Pre-Sales</Department>" & vbCr & vbLf & 
     	                   "<Department>Marketing</Department>" & vbCr & vbLf & 
     	                   "<Department>Finance</Department>" & vbCr & vbLf & 
                           "</Departments>"

      Dim xdoc As New XDocument()
      xdoc = XDocument.Parse(myXML)
     
      xdoc.Descendants().Where(Function(s) s.Value = "Sales").Remove()

      Dim result = xdoc.Element("Departments").Descendants()

      For Each item As XElement In result
         Console.WriteLine("Department Name - " + item.Value)
      Next

      Console.WriteLine(vbLf & "Press any key to continue.")
      Console.ReadKey()
	  
   End Sub
   
End Module

上記のC#またはVBのコードをコンパイルして実行すると、次の結果が得られます。

Department Name - Support
Department Name - Account
Department Name - Pre-Sales
Department Name - Marketing
Department Name - Finance

Press any key to continue.

ADO.NET EntityFrameworkの一部であるLINQto Entitiesは、LINQ to SQLよりも柔軟性がありますが、その複雑さと主要な機能の欠如のため、あまり人気がありません。ただし、LINQ to Entitiesは、Oracle、MySQLなどの多数のデータプロバイダーでのデータクエリを容易にするため、SQLサーバーデータベースでのみデータクエリを許可するLINQ toSQLの制限はありません。

さらに、ユーザーがLINQを介してエンティティへのクエリを実行するためにデータソース管理を利用でき、追加のコーディングを必要とせずに結果のバインドを容易にするという意味で、ASP.Netから大きなサポートを受けています。

LINQ to Entitiesは、これらの利点のために、今日のデータベースでLINQを使用するための標準メカニズムになっています。LINQ to Entitiesを使用すると、クエリされたデータの詳細を変更したり、バッチ更新を簡単にコミットしたりすることもできます。LINQ to Entitiesの最も興味深い事実は、SQLと同じ構文を持ち、Join、Select、OrderByなどの標準クエリ演算子の同じグループを持っていることです。

LINQ toEntitiesクエリの作成と実行のプロセス

  • の建設 ObjectQuery からのインスタンス ObjectContext (エンティティ接続)

  • 新しく構築されたインスタンスを使用して、C#またはVisual Basic(VB)でクエリを作成する

  • LINQの標準クエリ演算子とLINQ式のコマンドツリーへの変換

  • 発生した例外をクライアントに直接渡すクエリを実行する

  • すべてのクエリ結果をクライアントに返す

ObjectContext ここに、相互作用を可能にするプライマリクラスがあります Entity Data Modelつまり、LINQをデータベースに接続するブリッジとして機能します。コマンドツリーは、ここではEntityFrameworkと互換性のあるクエリ表現です。

一方、EntityFrameworkは実際には Object Relational Mapperデータベーステーブルに従ってビジネスオブジェクトとエンティティの生成を行い、作成、更新、削除、読み取りなどのさまざまな基本操作を容易にする開発者によって、一般にORMと略されます。次の図は、エンティティフレームワークとそのコンポーネントを示しています。

エンティティモデルでLINQを使用したADD、UPDATE、およびDELETEの例

まず、以下の手順に従ってエンティティモデルを追加します。

Step 1−プロジェクトを右クリックし、[新しいアイテムの追加]をクリックすると、以下のようなウィンドウが開きます。ADO.NETエンティティデータモデルを選択し、名前を指定して、[追加]をクリックします。

Step 2 −選択 Generate from database.

Step 3 −ドロップダウンメニューから[データベース接続]を選択します。

Step 4 −すべてのテーブルを選択します。

次のコードを記述します。

using DataAccess;
using System;
using System.Linq;

namespace LINQTOSQLConsoleApp {
   public class LinqToEntityModel {
      static void Main(string[] args) {

         using (LinqToSQLDBEntities context = new LinqToSQLDBEntities()) {
            //Get the List of Departments from Database
            var departmentList = from d in context.Departments
            select d;

            foreach (var dept in departmentList) {
               Console.WriteLine("Department Id = {0} , Department Name = {1}",
                  dept.DepartmentId, dept.Name);
            }

            //Add new Department
            DataAccess.Department department = new DataAccess.Department();
            department.Name = "Support";

            context.Departments.Add(department);
            context.SaveChanges();

            Console.WriteLine("Department Name = Support is inserted in Database");

            //Update existing Department
            DataAccess.Department updateDepartment = context.Departments.FirstOrDefault(d ⇒d.DepartmentId == 1);
            updateDepartment.Name = "Account updated";
            context.SaveChanges();

            Console.WriteLine("Department Name = Account is updated in Database");

            //Delete existing Department
            DataAccess.Department deleteDepartment = context.Departments.FirstOrDefault(d ⇒d.DepartmentId == 3);
            context.Departments.Remove(deleteDepartment);
            context.SaveChanges();

            Console.WriteLine("Department Name = Pre-Sales is deleted in Database");

            //Get the Updated List of Departments from Database
            departmentList = from d in context.Departments
            select d;

            foreach (var dept in departmentList) {
               Console.WriteLine("Department Id = {0} , Department Name = {1}",
                  dept.DepartmentId, dept.Name);
            }
         }

         Console.WriteLine("\nPress any key to continue.");
         Console.ReadKey();
      }
   }
}

上記のコードをコンパイルして実行すると、次の結果が得られます。

「ラムダ式」という用語は、「ラムダ」計算からその名前が付けられました。これは、関数を定義するために適用される数学表記です。LINQ方程式の実行可能部分としてのラムダ式は、実行時にロジックを変換するため、データソースに簡単に渡すことができます。ただし、ラムダ式は、LINQでのみアプリケーションを見つけることに限定されていません。

これらの式は、次の構文で表されます。

(Input parameters) ⇒ Expression or statement block

これがラムダ式の例です-

y⇒y* y

上記の式はyという名前のパラメーターを指定し、yの値は2乗されます。ただし、この形式でラムダ式を実行することはできません。C#でのラムダ式の例を以下に示します。

C#

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;

namespace lambdaexample {
   class Program {

      delegate int del(int i);
      static void Main(string[] args) {

         del myDelegate = y ⇒ y * y;
         int j = myDelegate(5);
         Console.WriteLine(j);
         Console.ReadLine();
      }
   }
}

VB

Module Module1
   Private Delegate Function del(ByVal i As Integer) As Integer
   
   Sub Main(ByVal args As String())
   
      Dim myDelegate As del = Function(y) y * y
      Dim j As Integer = myDelegate(5)
      Console.WriteLine(j)
      Console.ReadLine()
	  
   End Sub
   
End Module

上記のC#またはVBのコードをコンパイルして実行すると、次の結果が得られます。

25

式ラムダ

上記のラムダ式の構文の式は右側にあるため、これらは式ラムダとも呼ばれます。

非同期ラムダ

asyncキーワードを使用して非同期処理を組み込んで作成されたラムダ式は、非同期ラムダと呼ばれます。以下は非同期ラムダの例です。

Func<Task<string>> getWordAsync = async()⇒ “hello”;

標準クエリ演算子のラムダ

クエリ演算子内のラムダ式は、要求に応じて同じものによって評価され、シーケンス全体ではなく、入力シーケンスの各要素に対して継続的に機能します。開発者は、Lambda式によって、独自のロジックを標準のクエリ演算子にフィードすることができます。以下の例では、開発者は「Where」演算子を使用して、ラムダ式を使用して、指定されたリストから奇数値を再利用しています。

C#

//Get the average of the odd Fibonacci numbers in the series... 

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;

namespace lambdaexample {
   class Program {     
      static void Main(string[] args) {
      
         int[] fibNum = { 1, 1, 2, 3, 5, 8, 13, 21, 34 };
         double averageValue = fibNum.Where(num ⇒ num % 2 == 1).Average();
         Console.WriteLine(averageValue);
         Console.ReadLine();
      }
   }
}

VB

Module Module1

   Sub Main()
   
      Dim fibNum As Integer() = {1, 1, 2, 3, 5, 8, 13, 21, 34}
      Dim averageValue As Double = fibNum.Where(Function(num) num Mod 2 = 1).Average()
	  
      Console.WriteLine(averageValue)
      Console.ReadLine()
	  
   End Sub
   
End Module

上記のコードをコンパイルして実行すると、次の結果が得られます。

7.33333333333333

ラムダの型推論

C#では、型推論はさまざまな状況で便利に使用され、型を明示的に指定しなくても使用できます。ただし、ラムダ式の場合、型推論は、コンパイラーが満たされる必要があるため、各型が指定されている場合にのみ機能します。次の例を考えてみましょう。

delegate int Transformer (int i);

ここで、コンパイラーは型推論を使用して、xが整数であるという事実を利用します。これは、Transformerのパラメーター型を調べることによって行われます。

ラムダ式の可変スコープ

ラムダ式内で開始される変数が外部メソッドで表示されることを意図していないように、ラムダ式で変数スコープを使用する際にはいくつかのルールがあります。キャプチャされた変数は、それを参照するデリゲートがガベージコレクションの対象にならない限り、ガベージコレクションされないという規則もあります。さらに、ラムダ式内のreturnステートメントがそれを囲むメソッドの戻りを引き起こすことを禁止するルールがあります。

ラムダ式の変数スコープを示す例を次に示します。

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;

namespace lambdaexample {
   class Program {
      delegate bool D();
      delegate bool D2(int i);

      class Test {
         D del;
         D2 del2;
			
         public void TestMethod(int input) {
            int j = 0;
            // Initialize the delegates with lambda expressions.
            // Note access to 2 outer variables.
            // del will be invoked within this method.
            del = () ⇒ { j = 10; return j > input; };

            // del2 will be invoked after TestMethod goes out of scope.
            del2 = (x) ⇒ { return x == j; };

            // Demonstrate value of j:            
            // The delegate has not been invoked yet.
            Console.WriteLine("j = {0}", j);        // Invoke the delegate.
            bool boolResult = del();
           
            Console.WriteLine("j = {0}. b = {1}", j, boolResult);
         }

         static void Main() {
            Test test = new Test();
            test.TestMethod(5);

            // Prove that del2 still has a copy of
            // local variable j from TestMethod.
            bool result = test.del2(10);
           
            Console.WriteLine(result);

            Console.ReadKey();
         }
      }
   }
}

上記のコードをコンパイルして実行すると、次の結果が得られます。

j = 0
j = 10. b = True
True

式ツリー

ラムダ式はで使用されます Expression Tree広範囲に建設。式ツリーは、すべてのノード自体がメソッド呼び出しのような式であるか、x <yのような二項演算であるツリーに似たデータ構造のコードを提供します。以下は、式ツリーを構築するためのラムダ式の使用例です。

ステートメントラムダ

もあります statement lambdas2つまたは3つのステートメントで構成されますが、式ツリーの構築には使用されません。returnステートメントは、ステートメントlambdaで記述する必要があります。

ステートメントラムダの構文

(params)⇒ {statements}

ステートメントラムダの例

using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Linq.Expressions;

namespace lambdaexample {
   class Program {
      static void Main(string[] args) {
         int[] source = new[] { 3, 8, 4, 6, 1, 7, 9, 2, 4, 8 };

         foreach (int i in source.Where(x ⇒ 
            {
               if (x <= 3)
                  return true;
               else if (x >= 7)
                  return true;
               return false;
            }
         ))
        Console.WriteLine(i);
        Console.ReadLine();
      }
   }
}

上記のコードをコンパイルして実行すると、次の結果が得られます。

3
8
1
7
9
2
8

ラムダは、メソッドに基づくLINQクエリの引数として使用され、次のような演算子の左側に配置することはできません。 is または as匿名メソッドと同じように。Lambda式は匿名メソッドによく似ていますが、デリゲートとしてのみ使用するように制限されているわけではありません。

ラムダ式を使用する際の注意点

  • ラムダ式は値を返すことができ、パラメーターを持つことができます。

  • パラメータは、ラムダ式を使用して無数の方法で定義できます。

  • ラムダ式に単一のステートメントがある場合は中括弧は必要ありませんが、複数のステートメントがある場合は、中括弧と戻り値を記述する必要があります。

  • ラムダ式を使用すると、クロージャーと呼ばれる機能によってラムダ式ブロックの外部にある変数にアクセスできます。クロージャーの使用は、問題を回避するために慎重に行う必要があります。

  • ラムダ式内で安全でないコードを実行することは不可能です。

  • ラムダ式は、オペレーターの左側で使用するためのものではありません。

.NET Framework拡張機能のセットとして、LINQはASP.NET開発者によるデータアクセスに推奨されるメカニズムです。ASP.NET 3.5には、ASP.NETでLINQを簡単に使用できるようにする組み込みツールLINQDataSourceコントロールがあります。ASP.NETは、上記のコントロールをデータソースとして使用します。実際のプロジェクトには主にWebサイトまたはWindowsアプリケーションが含まれるため、ASP.NETを使用したLINQの概念をよりよく理解するために、LINQ機能を利用するASP.NETWebサイトの作成から始めましょう。

このためには、システムにVisualStudioと.NETFrameworkをインストールすることが不可欠です。Visual Studioを開いたら、[ファイル]→[新規]→[Webサイト]に移動します。下の図に示すように、ポップアップウィンドウが開きます。

これで、左側のテンプレートの下に、Webサイトを作成するための2つの言語オプションがあります。選択Visual C# 選択します ASP.NET Empty Web Site

システムに新しいWebサイトを保存するフォルダーを選択します。次にを押しますOK 等々 Solution ExplorerすべてのWebファイルを含む画面にが表示されます。ソリューションエクスプローラーでDefault.aspxを右クリックし、[ブラウザーで表示]を選択して、ブラウザーでデフォルトのASP.NETWebサイトを表示します。次のスクリーンショットに示すように、まもなく新しいASP.NETWebサイトがWebブラウザーで開きます。

.aspxは、実際、ASP.NETWebサイトで使用される主要なファイル拡張子です。Visual Studioは、デフォルトで、次のような基本的なWebサイトに必要なすべてのページを作成します。Home page そして About Usコンテンツを便利に配置できるページ。ウェブサイトのコードはここで自動的に生成され、表示することもできます。

LINQDataSourceコントロール

可能です UPDATE, INSERT そして DELETELINQDataSourceコントロールを使用したASP.NETWebサイトのページのデータ。LINQDataSourceコントロールは動的に作成されたコマンドをそのような操作に使用するため、SQLコマンドを指定する必要はまったくありません。

このコントロールを使用すると、ユーザーは、マークアップテキストのプロパティ設定により、ASP.NETWebページでLINQを簡単に利用できます。LINQDataSourceは、次のようなコントロールのデータデータと非常によく似ています。SqlDataSource と同様 ObjectDataSourceページに存在する他のASP.NETコントロールをデータソースにバインドする際に使用できるためです。だから、私たちは持っている必要がありますdatabase LINQDataSourceコントロールによって呼び出されるさまざまな関数を説明します。

ASP.NET Webページフォームでのコントロールの使用法の説明を開始する前に、Microsoft Visual Studio Toolboxを開き、下の図のようにLINQDataSourceコントロールをASP.NETWebサイトの.aspxページにドラッグアンドドロップすることが不可欠です。

次のステップは、従業員レコードのすべての列を選択してLINQDataSourceを構成することです。

次に、GridViewコントロールを.aspxページに追加し、次の図に示すように構成します。GridViewコントロールは強力で、データを操作するための柔軟性を提供します。コントロールを設定するとすぐに、ブラウザに表示されます。

.aspxページの画面に表示できるコーディングは次のようになります-

<!DOCTYPE html>

<html>
   <head runat = "server">
      <title></title>
   </head>

   <body>
      <form id = "form1" runat = "server">
         <div>
            <asp:GridView ID = "GridView1" runat = "server" AutoGenerateColumns = "False"
			
               DataKeyNames = "ContactID" DataSourceID = "LINQDataSource1">
               <Columns>
			   
                  <asp:BoundField DataField = "ContactID" HeaderText = "ContactID"
                     InsertVisible = "False" ReadOnly="True" SortExpression = "ContactID" />
                  <asp:CheckBoxField DataField = "NameStyle" HeaderText = "NameStyle"
                     SortExpression = "NameStyle" />
                  <asp:BoundField DataField = "Title" HeaderText = "Title" SortExpression = "Title" />
                  <asp:BoundField DataField = "FirstName" HeaderText = "FirstName"
                     SortExpression="FirstName" />
                  <asp:BoundField DataField = "MiddleName" HeaderText = "MiddleName"
                     SortExpression = "MiddleName" />
                  <asp:BoundField DataField = "LastName" HeaderText = "LastName"
                     SortExpression = "LastName" />
                  <asp:BoundField DataField = "Suffix" HeaderText = "Suffix"
                     SortExpression = "Suffix" />
                  <asp:BoundField DataField = "EmailAddress" HeaderText = "EmailAddress"
                     SortExpression = "EmailAddress" />
               </Columns>

            </asp:GridView>

            <br />

         </div>

         <asp:LINQDataSource ID = "LINQDataSource1" runat = "server"

            ContextTypeName = "LINQWebApp1.AdventureWorksDataContext" EntityTypeName = ""
               TableName = "Contacts">

         </asp:LINQDataSource>
      </form>
   </body>
</html>

ここで、プロパティContextTypeNameをデータベースを表すクラスのプロパティに設定することが重要であることに注意してください。たとえば、このアクションはLINQDataSourceとデータベースの間に必要な接続を確立するため、ここではLINQWebApp1.AdventureWorksDataContextとして指定されています。

LINQを使用したASP.NETページのデータの挿入、更新、および削除

上記のすべての手順を厳密に完了したら、 LINQDataSource Tasks から LINQDataSource Control 次のスクリーンショットに示すように、[挿入を有効にする]、[更新を有効にする]、[削除を有効にする]の3つのボックスすべてを選択します。

間もなく、宣言型マークアップが次のように画面に表示されます。

<asp:LINQDataSource 
   ContextTypeName = "LINQWebApp1.AdventureWorksDataContext" 
   TableName = "Contacts" 
   EnableUpdate = "true" 
   EnableInsert = "true" 
   EnableDelete = "true" 
   ID = "LINQDataSource1" 
   runat = "server">
</asp:LINQDataSource>

複数の行と列があるため、グリッドビューコントロールの下に詳細ビューまたはマスターコントロールという名前の別のコントロールを.aspxフォームに追加して、グリッドの選択した行の詳細のみを表示することをお勧めします。詳細ビューコントロールから詳細ビュータスクを選択し、以下に示すようにチェックボックスを選択します。

ここで、変更を保存し、Ctrl + F5を押してブラウザでページを表示します。ここで、詳細ビューコントロールのレコードを削除、更新、挿入できます。