現象
Microsoft SQL Server 2012 または SQL Server 2014 Master Data Services (MDS) で、MDS Web サービスを使って数値属性を作成することを前提としています。 小数点の右側の桁数を指定しようとすると、正しくない精度が計算されます。 たとえば、次のようにして16桁の精度の10進数属性を作成しようとすると、次のようになります。
MetadataAttribute newAttribute = new MetadataAttribute(); newAttribute.DataType = AttributeDataType.Number; newAttribute.DataTypeInformation = 16;
正しい小数点以下の桁数が16で、精度が22の列が作成されます。
原因
この問題が発生するのは、内部 MDS ストアドプロシージャが、属性を作成するときに、正しくない精度計算を使用しているためです。 有効桁数は38からスケールを差し引いた値であるため、精度は正しくありません。
解決方法
この問題は、SQL Server の次の累積的な更新プログラムで最初に修正されました。
SQL Server 2014 の累積更新プログラム1 /en-us/help/2931693
SQL Server 2012 SP1 の累積更新プログラム9 /en-us/help/2931078
SQL Server 用の新しい累積更新プログラムには、以前の累積的な更新プログラムに含まれていたすべての修正プログラムとすべてのセキュリティ修正が含まれています。 SQL Server の最新の累積的な更新プログラムを確認します。
回避策
この問題を回避するには、お客様の状況に合った次の方法を使用します。
-
SQL Server 2014 の場合は、修正プログラムを適用します。
-
SQL Server 2012 の場合は、精度の減算スケール (@DataTypeInformation など) ではなく、38の定数値 (SQL Server 2012 で許可される値) を使用するようにストアドプロシージャを変更します。
状態
マイクロソフトでは、この問題をこの資料の対象製品として記載されているマイクロソフト製品の問題として認識しています。