Перейти к основному содержимому

sum

Описание

Возвращает сумму ненулевых значений для expr. Вы можете использовать ключевое слово DISTINCT для вычисления суммы различных ненулевых значений.

Синтаксис

SUM([DISTINCT] expr)

Параметры

expr: выражение, которое вычисляется в числовое значение. Поддерживаемые типы данных: TINYINT, SMALLINT, INT, FLOAT, DOUBLE или DECIMAL.

Возвращаемое значение

Соответствие типов данных между входным значением и возвращаемым значением:

  • TINYINT -> BIGINT
  • SMALLINT -> BIGINT
  • INT -> BIGINT
  • FLOAT -> DOUBLE
  • DOUBLE -> DOUBLE
  • DECIMAL -> DECIMAL

Примечания по использованию

  • Эта функция игнорирует значения null.
  • Возвращается ошибка, если expr не существует.
  • Если передается выражение VARCHAR, эта функция неявно приводит входные данные к значениям DOUBLE. Если приведение типа не удается, возвращается ошибка.

Примеры

  1. Создайте таблицу с именем employees.

    CREATE TABLE IF NOT EXISTS employees (
    region_num TINYINT COMMENT "range [-128, 127]",
    id BIGINT COMMENT "range [-2^63 + 1 ~ 2^63 - 1]",
    hobby STRING NOT NULL COMMENT "upper limit value 65533 bytes",
    income DOUBLE COMMENT "8 bytes",
    sales DECIMAL(12,4) COMMENT ""
    )
    DISTRIBUTED BY HASH(region_num);
  2. Вставьте данные в employees.

    INSERT INTO employees VALUES
    (3,432175,'3',25600,1250.23),
    (4,567832,'3',37932,2564.33),
    (3,777326,'2',null,1932.99),
    (5,342611,'6',43727,45235.1),
    (2,403882,'4',36789,52872.4);
  3. Запросите данные из employees.

    MySQL > select * from employees;
    +------------+--------+-------+--------+------------+
    | region_num | id | hobby | income | sales |
    +------------+--------+-------+--------+------------+
    | 5 | 342611 | 6 | 43727 | 45235.1000 |
    | 2 | 403882 | 4 | 36789 | 52872.4000 |
    | 4 | 567832 | 3 | 37932 | 2564.3300 |
    | 3 | 432175 | 3 | 25600 | 1250.2300 |
    | 3 | 777326 | 2 | NULL | 1932.9900 |
    +------------+--------+-------+--------+------------+
    5 rows in set (0.01 sec)
  4. Используйте эту функцию для вычисления суммы.

    Пример 1: Вычислите общие продажи каждого региона.

    MySQL > SELECT region_num, sum(sales) from employees
    group by region_num;

    +------------+------------+
    | region_num | sum(sales) |
    +------------+------------+
    | 2 | 52872.4000 |
    | 5 | 45235.1000 |
    | 4 | 2564.3300 |
    | 3 | 3183.2200 |
    +------------+------------+
    4 rows in set (0.01 sec)

    Пример 2: Вычислите общий доход сотрудников каждого региона. Эта функция игнорирует значения null, и доход сотрудника с id 777326 не учитывается.

    MySQL > select region_num, sum(income) from employees
    group by region_num;

    +------------+-------------+
    | region_num | sum(income) |
    +------------+-------------+
    | 2 | 36789 |
    | 5 | 43727 |
    | 4 | 37932 |
    | 3 | 25600 |
    +------------+-------------+
    4 rows in set (0.01 sec)

    Пример 3: Вычислите общее количество хобби. Столбец hobby имеет тип STRING и будет неявно преобразован в DOUBLE во время вычисления.

    MySQL > select sum(DISTINCT hobby) from employees;

    +---------------------+
    | sum(DISTINCT hobby) |
    +---------------------+
    | 15 |
    +---------------------+
    1 row in set (0.01 sec)

    Пример 4: Используйте sum с предложением WHERE для вычисления общего дохода сотрудников, чей месячный доход превышает 30000.

    MySQL > select sum(income) from employees
    WHERE income > 30000;

    +-------------+
    | sum(income) |
    +-------------+
    | 118448 |
    +-------------+
    1 row in set (0.00 sec)

keyword

SUM, sum