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


Раздел — справочник по оператору многомерных выражений

Выполняет арифметическую операцию, которая делит одно число на другое.

Синтаксис

  
Dividend / Divisor  

Параметры

Дивидендов
Допустимое многомерное выражение, возвращающее числовое значение.

Делитель
Допустимое многомерное выражение, возвращающее числовое значение.

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

Значение с типом данных параметра, имеющего более высокий приоритет.

Замечания

Фактическое значение, возвращаемое оператором /(Деление), представляет кворот первого выражения, разделенного вторым выражением.

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

Примеры

В следующем примере демонстрируется использование этого оператора.

-- This query returns the freight cost per user,  
-- for products, averaged by month.   
With Member [Measures].[Freight Per Customer] as  
    [Measures].[Internet Freight Cost]  
    /   
    [Measures].[Customer Count]  
  
SELECT   
    [Ship Date].[Calendar].[Calendar Year] Members ON 0,  
    [Product].[Category].[Category].Members ON 1  
FROM  
    [Adventure Works]  
WHERE  
    ([Measures].[Freight Per Customer])  

При делении ненулевого значения или значения, отличного от NULL, на нуль или значение NULL будет возвращено значение «бесконечность», которое отображается в результатах запроса как значение «1.#INF». В большинстве случаев следует выполнять проверку деления на ноль, чтобы избежать этой ситуации. В следующем примере приведена иллюстрация этого:

//Returns 1.#INF when Internet Sales Amount is zero or null  
Member [Measures].[Reseller to Internet Ratio] AS  
[Measures].[Reseller Sales Amount]  
/  
[Measures].[Internet Sales Amount]  
//Traps the division by zero scenario and returns null instead of 1.#INF  
Member [Measures].[Reseller to Internet Ratio With Error Handling] AS  
IIF([Measures].[Internet Sales Amount]=0, NULL,  
[Measures].[Reseller Sales Amount]  
/  
[Measures].[Internet Sales Amount])  
SELECT  
{[Measures].[Reseller to Internet Ratio],[Measures].[Reseller to Internet Ratio With Error Handling]} ON 0,  
[Product].[Category].[Category].Members ON 1  
FROM  
[Adventure Works]  
WHERE([Date].[Calendar].[Calendar Year].&[2001])  

См. также

IIf (многомерные выражения)
Справочник по оператору многомерных выражений (многомерные выражения)