この資料では、すべての国と言語ロケールのすべての Microsoft Dynamics NAV に該当します。
現象
Microsoft Dynamics NAV 2013 で複数の会社の分析コードのアップグレード ツールを実行すると、次のエラー メッセージが表示されます。
エラー: 'System.Data.SqlClient.SqlCommand.ExecuteNonQuery': データベースにある ' pk_dimXXXX_id' をという名前のオブジェクトが既に存在します。制約を作成できませんでした。
解決策
修正プログラムの情報
サポートされている修正プログラムはマイクロソフトから現在入手可能です。ただし、この資料に記載されている問題を解決するためのものはのみ。この特定の問題が発生したシステムにのみ適用してください。この修正プログラムは、今後さらにテストを行うことがあります。この問題で深刻な影響を受けていない場合は、次の Microsoft Dynamics NAV 2009 サービス パックまたは修正プログラムを含む次の Microsoft Dynamics NAV バージョン待つことを勧めします。
注: かかる料金が免除されるテクニカル サポート担当者 Microsoft Dynamics および関連製品のことは、通常は特別な場合は、特定の更新プログラムは、問題を解決するにを決定します。追加の質問および問題の特定のアップデートの対象にはなりませんが、通常のサポート料金が適用されます。
インストール情報
マイクロソフトでは解説することのみを目的としてプログラミング例を提供しています。暗示あるいは明示していることに対しての保証はしておりません。ここで言う保証とは、特定の目的に対する商品性や適合性の暗示的保証を含んでいますが、それに限定されるわけではありません。この資料では、例示されているプログラミング言語およびプロシージャの作成やデバッグに使用するツールにお客様が精通していることを前提としています。マイクロソフトのサポート エンジニアは、特定のプロシージャの機能を説明することができますが、機能の追加またはお客様固有の要件を満たすようにプロシージャを作成するこれらの例は変更されません。
注: この修正プログラムをインストールする前に、Microsoft Navision のすべてのクライアント ユーザーがシステムの電源を記録することを確認します。これには、Microsoft Navision アプリケーション サービス (NAS) クライアントのユーザーが含まれます。この修正プログラムを実装すると、ログオンしている唯一のクライアント ユーザーが必要です。
この修正プログラムを実装するには、開発者用のライセンスが必要です。
ユーザー アカウントまたはデータベース ログイン ウィンドウに Windows のログイン ウィンドウにある「スーパー」ロール id を割り当てられていることをお勧めします。ユーザー アカウントには、「スーパー」ロール ID を割り当てることができません、する場合は、ユーザー アカウントが次のアクセス許可を持っているを確認する必要があります。
-
変更するオブジェクトの変更のアクセス許可。
-
システム オブジェクトの ID 5210オブジェクトおよびシステム オブジェクトの ID 9015オブジェクトの実行が許可されます。
注:
データの修復を実行する必要があるない限り、データ ストアへの権限を持っている必要はありません。
コードの変更
注: 常にテスト コードを修正、管理された環境で適用する前に、運用コンピューターに修正プログラムします。
この問題を解決するには、次の手順を実行します。
-
"アップグレード分析コードのエントリ-SQL"codeunit (104049) でグローバル変数のセクション内のコードを次のように変更します。
既存のコード...Window@1008 : Dialog;
NoOfDim@1007 : Integer;
DimTableKeyFields@1006 : ARRAY [16,2] OF Text[80];
ParentTableKeyFields@1005 : ARRAY [16,2] OF Text[80];
// Delete the following lines.
TableNameUpgradeDimTable@1004 : Text[80];
TableNameUpgradeDimSetID@1001 : Text[80];
TableNameUpgradeTableID@1000 : Text[80];
// End of the lines.
PROCEDURE UpgradeTable@10(DimTableID@1000 : Integer;ParentTableID@1001 : Integer);
VAR
RecRef@1002 : RecordRef;
...置換用コード
...Window@1008 : Dialog;
NoOfDim@1007 : Integer;
DimTableKeyFields@1006 : ARRAY [16,2] OF Text[80];
ParentTableKeyFields@1005 : ARRAY [16,2] OF Text[80];
// Add the following lines.
TableNameUpgradeDimTable@1004 : Text;
TableNameUpgradeDimSetID@1001 : Text;
TableNameUpgradeTableID@1000 : Text;
// End of the lines.
PROCEDURE UpgradeTable@10(DimTableID@1000 : Integer;ParentTableID@1001 : Integer);
VAR
RecRef@1002 : RecordRef;
... -
"アップグレード分析コードのエントリ-SQL"codeunit (104049) 内の CreateTablesQry 関数内のコードを次のように変更します。
既存のコード 1...i@1001 : Integer;
DimNo@1000 : Integer;
BEGIN
TableNameUpgradeDimTable := STRSUBSTNO('%1$upgrade%2_Dim',SQLMgt.StringConvert(COMPANYNAME),DimTableID);
// Delete the following line,
TableNameUpgradeDimSetID := STRSUBSTNO('%1$upgrade%2_DimSetID',SQLMgt.StringConvert(COMPANYNAME),DimTableID);
TableNameUpgradeTableID := STRSUBSTNO('%1$upgrade%2_TableID',SQLMgt.StringConvert(COMPANYNAME),DimTableID);
DimEntryQry := 'select DISTINCT';
i := 1;
...置換用コード 1
...i@1001 : Integer;
DimNo@1000 : Integer;
BEGIN
TableNameUpgradeDimTable := STRSUBSTNO('%1$upgrade%2_Dim',SQLMgt.StringConvert(COMPANYNAME),DimTableID);
// Add the following line.
TableNameUpgradeDimSetID := STRSUBSTNO('%1$upgrade%2_DimSetID_%3',SQLMgt.StringConvert(COMPANYNAME),DimTableID,CREATEGUID);
TableNameUpgradeTableID := STRSUBSTNO('%1$upgrade%2_TableID',SQLMgt.StringConvert(COMPANYNAME),DimTableID);
DimEntryQry := 'select DISTINCT';
i := 1;
...既存のコード 2
...DimSetQry :=
DimSetQry +
STRSUBSTNO(
' alter table [%1] add ID int identity ' +
// Delete the following lines.
' alter table [%1] add constraint pk_dim%2_id primary key (ID) ',
TableNameUpgradeDimSetID,DimTableID);
// End of the lines.
i := 1;
WHILE (i < 5) AND (DimTableKeyFields[i + 1,1] <> '') DO BEGIN
IF i > 1 THEN
...置換用コード 2
...DimSetQry :=
DimSetQry +
STRSUBSTNO(
' alter table [%1] add ID int identity ' +
// Add the following lines.
' alter table [%1] add constraint [pk_dim%2_id_%3] primary key (ID) ',
TableNameUpgradeDimSetID,DimTableID,CREATEGUID);
// End of the lines.
i := 1;
WHILE (i < 5) AND (DimTableKeyFields[i + 1,1] <> '') DO BEGIN
IF i > 1 THEN
...
必要条件
Microsoft Dynamics NAV 2013 がこの修正プログラムを適用するためにインストールする必要があります。
アンインストール情報
この修正プログラムを削除することはできません。
状況
マイクロソフトは、この問題を「対象製品」セクションに記載されているマイクロソフト製品の問題として認識しています。
注: これは、マイクロソフト サポートの組織内から直接作成した「高速公開」の資料です。ここに含まれる情報は、新たに発生している問題に応じて現状のまま提供されています。速やかに利用できるようにした結果として、内容には誤植が含まれている可能性があり、事前告知なしで改訂する場合があります。その他の考慮事項については、使用条件を参照してください。