空の値の操作
空の値は、特定のメンバ、組、またはセルが空であることを示します。空のセル値は、指定されたセルのデータが基になるファクト テーブルに見つからないこと、あるいは指定されたセルの組の表すメンバの組み合わせをキューブに適用できないことのいずれかを示します。
注 |
---|
空の値は 0 の値とは異なりますが、ほとんどの場合に 0 として扱われます。 |
次のクエリでは、空の値と 0 の動作を示しています。
WITH
//A calculated Product Category that always returns 0
MEMBER [Product].[Category].[All Products].ReturnZero AS 0
//Will return true for any null value
MEMBER MEASURES.ISEMPTYDemo AS ISEMPTY([Measures].[Internet Tax Amount])
//Will true for any null or zero value
//To be clear: the expression 0=null always returns true in MDX
MEMBER MEASURES.IsZero AS [Measures].[Internet Tax Amount]=0
SELECT
{[Measures].[Internet Tax Amount],MEASURES.ISEMPTYDemo,MEASURES.IsZero}
ON COLUMNS,
[Product].[Category].[Category].ALLMEMBERS
ON ROWS
FROM [Adventure Works]
WHERE([Date].[Calendar].[Calendar Year].&[2001])
空の値には以下の情報が当てはまります。
IsEmpty 関数が TRUE を返すのは、関数に指定されている組で識別されるセルが空の場合に限られます。そうでない場合は、FALSE を返します。
注 IsEmpty 関数は、メンバ式が NULL 値を返すかどうかを判断できません。式から NULL メンバが返されたかどうかを確認するには、IS演算子を使用します。
空のセル値が数値演算子 (+、-、*、/) のいずれかのオペランドである場合、もう一方のオペランドが空でない値であるなら、空のセル値は 0 として扱われます。オペランドが両方とも空なら、数値演算子は空のセル値を返します。
空のセル値が文字列連結演算子 (+) のオペランドである場合、もう一方のオペランドが空でない値であるなら、空のセル値は空の文字列として扱われます。オペランドが両方とも空なら、文字列連結演算子は空のセル値を返します。
空のセル値が比較演算子 (=、<>、>=、<=、>、<) のいずれかのオペランドである場合、もう一方のオペランドが数値であるか文字列であるかに応じて、空のセル値は 0 または空の文字列として扱われます。オペランドが両方とも空なら、どちらも 0 として扱われます。
数値を照合する場合、空のセル値の照合順序は、0 と同じ位置になります。空のセル値と 0 との照合の場合、空のセル値の照合順序は、0 の前になります。
文字列の値を照合する場合、空のセル値の照合順序は、空の文字列と同じ位置になります。空のセル値と空の文字列との照合の場合、空のセル値の照合順序は、空の文字列の前になります。
MDX ステートメントおよびキューブにおける空の値の処理
多次元式 (MDX) ステートメントでは、空の値を探してから、有効な (空でない) データの入ったセルに対して計算を実行することができます。計算時に空の値を除去することが必要な場合があります。平均値などの計算では、空のセル値が含まれていると正確な結果を得ることができません。
空の値が基になるファクト テーブル データに格納されると、既定では、キューブが処理される際にこの値が 0 に変換されます。メジャーに対して [NULL 処理] オプションを使用すると、NULL を 0 または空の値に変換するか、処理中にエラーをスローするかを制御することができます。空のセル値がクエリ結果に表示されないようにするには、空の値を除去するか他の値に置き換えるクエリ、計算されるメンバ、または MDX スクリプト ステートメントを作成する必要があります。
クエリから空の行や列を削除するには、軸セットの定義の前に NON EMPTY ステートメントを使用できます。たとえば、次のクエリでは、製品カテゴリ Bikes のみが返されます。これは、2001 年に販売された唯一のカテゴリであるためです。
SELECT
{[Measures].[Internet Tax Amount]}
ON COLUMNS,
//Comment out the following line to display all the empty rows for other Categories
NON EMPTY
[Product].[Category].[Category].MEMBERS
ON ROWS
FROM [Adventure Works]
WHERE([Date].[Calendar].[Calendar Year].&[2001])
セットから空の組を削除するには、NonEmpty 関数を使用する方法がより一般的です。次のクエリでは、2 つの計算されるメジャーを示しています。1 つは、製品カテゴリの数をカウントし、もう 1 つは、[Internet Tax Amount] メジャーと 2001 年の値を持つ製品カテゴリの数を示します。
WITH
MEMBER MEASURES.CategoryCount AS
COUNT([Product].[Category].[Category].MEMBERS)
MEMBER MEASURES.NonEmptyCategoryCountFor2001 AS
COUNT(
NONEMPTY(
[Product].[Category].[Category].MEMBERS
,([Date].[Calendar].[Calendar Year].&[2001], [Measures].[Internet Tax Amount])
))
SELECT
{MEASURES.CategoryCount,MEASURES.NonEmptyCategoryCountFor2001 }
ON COLUMNS
FROM [Adventure Works]
詳細については、「NonEmpty (MDX)」を参照してください。
空の値と比較演算子
データに空の値がある場合、論理演算子と比較演算子は、TRUE または FALSE ではなく EMPTY を返すことがあります。このように 3 つの値を生成する論理は、アプリケーション エラーの原因になります。次の表は、空の値の比較を採用した場合の結果を示しています。
下の表は、AND 演算子を 2 つのブール値オペランドに適用した結果を示します。
AND |
TRUE |
EMPTY |
FALSE |
---|---|---|---|
TRUE |
TRUE |
FALSE |
FALSE |
EMPTY |
FALSE |
EMPTY |
FALSE |
FALSE |
FALSE |
FALSE |
FALSE |
下の表は、OR 演算子を 2 つのブール値オペランドに適用した結果を示します。
OR |
TRUE |
FALSE |
---|---|---|
TRUE |
TRUE |
TRUE |
EMPTY |
TRUE |
TRUE |
FALSE |
TRUE |
FALSE |
下の表は、NOT 演算子が論理演算子の結果を否定または逆転するようすを示します。
NOT 演算子が適用されるブール式 |
評価結果 |
---|---|
TRUE |
FALSE |
EMPTY |
EMPTY |
FALSE |
TRUE |