メインコンテンツへスキップ
  • SELECT
  • INTO
  • FROM
  • JOIN
  • WHERE
  • GROUP BY
  • HAVING
  • UNION
  • ORDER BY
  • LIMIT

SELECT 構文

以下の構文図は、プロバイダーの SQL エンジンがサポートする構文を示しています。
SELECT {
  [ TOP <numeric_literal> | DISTINCT ]
  { 
    * 
    | { 
        <expression> [ [ AS ] <column_reference> ] 
        | { <table_name> | <correlation_name> } .* 
      } [ , ... ] 
  }
  { 
    FROM <table_reference> [ [ AS ] <identifier> ] 
  } [ , ... ]
  [ [  
      INNER | { { LEFT | RIGHT | FULL } [ OUTER ] } 
    ] JOIN <table_reference> [ ON <search_condition> ] [ [ AS ] <identifier> ] 
  ] [ ... ] 
  [ WHERE <search_condition> ]
  [ GROUP BY <column_reference> [ , ... ] ]
  [ HAVING <search_condition> ]
  [ UNION [ ALL ] <select_statement> ]
  [ 
    ORDER BY 
    <column_reference> [ ASC | DESC ] [ NULLS FIRST | NULLS LAST ]
  ]
  [ 
    LIMIT <expression>
    [ 
      { OFFSET | , }
      <expression> 
    ]
  ] 
} | SCOPE_IDENTITY()

<expression> ::=
  | <column_reference>
  | @ <parameter>
  | ?
  | COUNT( * | { [ DISTINCT ] <expression> } )
  | { AVG | MAX | MIN | SUM | COUNT } ( <expression> )
  | NULLIF ( <expression> , ... )
  | CASE <expression>
      WHEN { <expression> | <search_condition> } THEN { <expression> | NULL } [ ... ]
    [ ELSE { <expression> | NULL } ]
    END
  | <literal>
  | <sql_function>

<search_condition> ::=
  {
    <expression> { = | > | < | >= | <= | <> | != | LIKE | NOT LIKE | IN | NOT IN | IS NULL | IS NOT NULL | AND | OR |  
    CONTAINS | BETWEEN } [ <expression> ]
  } [ { AND | OR } ... ]

  1. すべてのカラムを返す:
SELECT * FROM [Connection Name].[Schema].[Table Name]
  1. カラムの名前を変更する:
SELECT [Name] AS MY_Name FROM Account
  1. カラムのデータを別のデータ型にキャストする:
SELECT CAST(AnnualRevenue AS VARCHAR) AS Str_AnnualRevenue FROM Account
  1. データを検索する:
SELECT * FROM Account WHERE Industry = \`\`'Floppy Disks'\`\`
  1. クエリ条件に一致するアイテムの数を返す:
SELECT COUNT(*) AS MyCount FROM Account
  1. クエリ条件に一致する一意のアイテムの数を返す:
SELECT COUNT(DISTINCT Name) FROM Account
  1. クエリ条件に一致する一意のアイテムを返す:
SELECT DISTINCT Name FROM Account
  1. データを集計する:
SELECT Name, MAX(AnnualRevenue) FROM Account GROUP BY Name
  1. 複数のテーブルからデータを取得する:
SELECT Customers.ContactName, Orders.OrderDate FROM Customers, Orders WHERE Customers.CustomerId=Orders.CustomerId
  1. 結果セットを昇順で並べ替える:
SELECT BillingState, Name FROM Account ORDER BY Name ASC
  1. 結果セットを指定した行数に制限する:
SELECT BillingState, Name FROM Account LIMIT 10
  1. クエリをパラメータ化して実行時に入力を渡す。これにより、プリペアドステートメントを作成し、SQL インジェクション攻撃を防ぐことができます。
SELECT * FROM Account WHERE Industry = @param