Поделиться через


% (остаток от деления) (Transact-SQL)

Область применения: SQL Server База данных SQL Azure Управляемый экземпляр SQL Azure конечной точке аналитики платформы Аналитики Azure Synapse Analytics (PDW) в Microsoft Fabric Хранилище в Microsoft Fabric

Возвращает остаток от деления одного числа на другое.

Соглашения о синтаксисе Transact-SQL

Синтаксис

dividend % divisor

Аргументы

dividend

Делимое числовое выражение. Аргумент dividend должен быть допустимым выражением любого типа из категорий целочисленных или денежных типов данных или типа numeric.

divisor

Числовое выражение, по которому необходимо разделить дивиденды. Аргумент divisor должен быть допустимым выражением любого типа из категорий целочисленных или денежных типов данных или типа numeric.

Типы результата

Определяются типами данных обоих аргументов.

Замечания

Можно использовать арифметический оператор модула в списке SELECT выбора инструкции с любым сочетанием имен столбцов, числовых констант или любого допустимого выражения категорий целочисленных и денежных типов данных или числовых типов данных.

Примеры

Примеры кода Transact-SQL в этой статье используют AdventureWorks2022 базу данных или AdventureWorksDW2022 пример базы данных, которую можно скачать с домашней страницы примеров и проектов сообщества Microsoft SQL Server.

А. Простой пример

В следующем примере число 38 делится на 5. Результат является 7 целочисленной частью результата и демонстрирует, как модуло возвращает оставшуюся часть 3.

SELECT
    38 / 5 AS [Integer],
    38 % 5 AS [Remainder];

B. Пример с использованием столбцов в таблице

Следующий пример возвращает код продукта, цену единицы модуля продукта и остаток от деления цены каждого продукта, преобразовывает к целому значению, в количество заказанных продуктов.

SELECT TOP (100) ProductID,
    UnitPrice,
    OrderQty,
    CAST((UnitPrice) AS INT) % OrderQty AS Modulo
FROM Sales.SalesOrderDetail;
GO

Примеры: Azure Synapse Analytics и система платформы аналитики (PDW)

C: базовый пример

В следующем примере показаны результаты для % оператора при делении 3 на 2.

SELECT TOP(1) 3 % 2
FROM DimEmployee;

Вот результирующий набор.

1