SQL - 表达式

  • 简述

    表达式是一个或多个值、运算符和计算为一个值的 SQL 函数的组合。这些 SQL 表达式类似于公式,它们是用查询语言编写的。您还可以使用它们来查询数据库中的特定数据集。

    句法

    考虑 SELECT 语句的基本语法如下 -
    
    SELECT column1, column2, columnN 
    FROM table_name 
    WHERE [CONDITION|EXPRESSION];
    
    有不同类型的 SQL 表达式,如下所述 -
    • 布尔值
    • 数字
    • 日期
    现在让我们详细讨论其中的每一个。
  • 布尔表达式

    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)