WebSurfer's Home

トップ > Blog 1   |   Login
Filter by APML

SQL Server の IN 演算子の利用

by WebSurfer 5. August 2010 12:31

DB のテーブルから一つの項目を選び、その項目の詳細を表示するというケースはよくあると思います。そのようなサンプルは Web から容易に見つかると思います。

では、一度に複数の項目を選んで、複数の項目の詳細を同時に表示するにはどうすればいいでしょうか?

SQL Server には IN 演算子というものがあって、それを利用するのがよさそうです。以下は SQL Server 2005 Online Book のサンプルです。

SELECT FirstName, LastName, e.Title
FROM HumanResources.Employee AS e
    JOIN Person.Contact AS c 
    ON e.ContactID = c.ContactID
WHERE e.Title IN ('Design Engineer', 'Tool Designer', 'Marketing Assistant');

ASP.NET のアプリでは、CheckBoxList で複数の項目を選んで、Button クリックで GridView に選んだ項目の詳細を表示することを考えます。

ユーザーの選択結果によって動的にクエリ(上記で言うと、IN (...) の ... の部分)を変える必要があります。

他にもっとスマートなやり方があるかもしれませんが、プログラムで SELECT クエリを組み立てて処置するサンプルを書いておきます。

DB は Microsoft が無償提供している Northwind サンプルデータベースの Orders テーブルを使用しました。

<%@ Page Language="C#" %>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<script runat="server">

  protected void Button1_Click(object sender, EventArgs e)
  {
    string selectedItems = "(";
    int count = 0;

    for (int i = 0; i < CheckBoxList1.Items.Count; i++)
    {
      if (CheckBoxList1.Items[i].Selected)
      {
        selectedItems += CheckBoxList1.Items[i].Value + ", ";
        count++;
      }
    }

    if (count > 0)
    {
      selectedItems = 
        selectedItems.TrimEnd(new char[] { ',', ' ' });
      selectedItems += ")";
      SqlDataSource2.SelectParameters.Clear();
      SqlDataSource2.SelectCommand = 
        "SELECT * FROM [orders] WHERE [EmployeeID] IN "
        + selectedItems + " ORDER BY [EmployeeID]";
    }
    else
    {
      SqlDataSource2.SelectParameters.Clear();
    }       
  }
</script>

<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
  <title>無題のページ</title>
</head>
<body>
  <form id="form1" runat="server">
  <div>
    <asp:SqlDataSource ID="SqlDataSource1" 
      runat="server"
      ConnectionString="<%$ ConnectionStrings:Northwind %>"
      SelectCommand="SELECT DISTINCT [EmployeeID] FROM [Orders] ORDER BY [EmployeeID]">
    </asp:SqlDataSource>
    <asp:CheckBoxList ID="CheckBoxList1" 
      runat="server"
      DataSourceID="SqlDataSource1" 
      DataTextField="EmployeeID"
      DataValueField="EmployeeID">
    </asp:CheckBoxList>
   
    <asp:Button ID="Button1" 
      runat="server" 
      Text="Show Selected Data"
      onclick="Button1_Click" />
       
    <asp:SqlDataSource ID="SqlDataSource2" 
      runat="server"
      ConnectionString="<%$ ConnectionStrings:Northwind %>" >
    </asp:SqlDataSource>
    <asp:GridView ID="GridView1" 
      runat="server" 
      DataSourceID="SqlDataSource2">
    </asp:GridView>   
  </div>
  </form>
</body>
</html>

Tags: ,

ASP.NET

About this blog

2010年5月にこのブログを立ち上げました。その後 ブログ2 を追加し、ここは ASP.NET 関係のトピックス、ブログ2はそれ以外のトピックスに分けました。

Calendar

<<  June 2021  >>
MoTuWeThFrSaSu
31123456
78910111213
14151617181920
21222324252627
2829301234
567891011

View posts in large calendar