SQL-式

式は、1つ以上の値、演算子、および値に評価されるSQL関数の組み合わせです。これらのSQL式は数式のようなもので、クエリ言語で記述されています。これらを使用して、特定のデータセットをデータベースに照会することもできます。

構文

SELECTステートメントの基本的な構文を次のように考えます-

SELECT column1, column2, columnN 
FROM table_name 
WHERE [CONDITION|EXPRESSION];

SQL式にはさまざまな種類があり、以下に説明します。

  • Boolean
  • Numeric
  • Date

これらのそれぞれについて詳しく説明しましょう。

ブール式

SQLブール式は、単一の値の一致に基づいてデータをフェッチします。以下は構文です-

SELECT column1, column2, columnN 
FROM table_name 
WHERE SINGLE VALUE MATCHING EXPRESSION;

次のレコードを持つCUSTOMERSテーブルについて考えてみます-

SQL> SELECT * FROM CUSTOMERS;
+----+----------+-----+-----------+----------+
| ID | NAME     | AGE | ADDRESS   | SALARY   |
+----+----------+-----+-----------+----------+
|  1 | Ramesh   |  32 | Ahmedabad |  2000.00 |
|  2 | Khilan   |  25 | Delhi     |  1500.00 |
|  3 | kaushik  |  23 | Kota      |  2000.00 |
|  4 | Chaitali |  25 | Mumbai    |  6500.00 |
|  5 | Hardik   |  27 | Bhopal    |  8500.00 |
|  6 | Komal    |  22 | MP        |  4500.00 |
|  7 | Muffy    |  24 | Indore    | 10000.00 |
+----+----------+-----+-----------+----------+
7 rows in set (0.00 sec)

次の表は、さまざまなSQLブール式の使用法を示す簡単な例です。

SQL> SELECT * FROM CUSTOMERS WHERE SALARY = 10000;
+----+-------+-----+---------+----------+
| ID | NAME  | AGE | ADDRESS | SALARY   |
+----+-------+-----+---------+----------+
|  7 | Muffy |  24 | Indore  | 10000.00 |
+----+-------+-----+---------+----------+
1 row in set (0.00 sec)

数式

これらの式は、クエリで数学演算を実行するために使用されます。以下は構文です-

SELECT numerical_expression as  OPERATION_NAME
[FROM table_name
WHERE CONDITION] ;

ここで、numeric_expressionは、数式または任意の式に使用されます。以下は、SQL数式の使用法を示す簡単な例です。

SQL> SELECT (15 + 6) AS ADDITION
+----------+
| ADDITION |
+----------+
|       21 |
+----------+
1 row in set (0.00 sec)

テーブルまたは特定のテーブル列に対して集計データ計算と呼ばれるものを実行するために、avg()、sum()、count()などのいくつかの組み込み関数があります。

SQL> SELECT COUNT(*) AS "RECORDS" FROM CUSTOMERS; 
+---------+
| RECORDS |
+---------+
|       7 |
+---------+
1 row in set (0.00 sec)

日付式

日付式は、現在のシステムの日付と時刻の値を返します-

SQL>  SELECT CURRENT_TIMESTAMP;
+---------------------+
| Current_Timestamp   |
+---------------------+
| 2009-11-12 06:40:23 |
+---------------------+
1 row in set (0.00 sec)

別の日付式は次のとおりです-

SQL>  SELECT  GETDATE();;
+-------------------------+
| GETDATE                 |
+-------------------------+
| 2009-10-22 12:07:18.140 |
+-------------------------+
1 row in set (0.00 sec)