Pierakstīties, izmantojot Microsoft
Pierakstieties vai izveidojiet kontu.
Sveicināti!
Atlasiet citu kontu.
Jums ir vairāki konti
Izvēlieties kontu, ar kuru vēlaties pierakstīties.

Šis raksts attiecas uz Microsoft Dynamics NAV visās valstīs un visu valodu lokalizācijas.

Pazīmes

Palaižot rīku jaunināšanas dimensijas daudzos uzņēmumos Microsoft Dynamics NAV 2013, tiek parādīts šāds kļūdas ziņojums:

KĻŪDA: "System.Data.SqlClient.SqlCommand.ExecuteNonQuery": jau ir objekts ar nosaukumu "pk_dimXXXX_id" datu bāzē. Nevarēja izveidot ierobežojums.


Risinājums

Informācija par labojumfailu

Pašlaik korporācija Microsoft piedāvā atbalstītu labojumfailu. Tomēr tas ir paredzēts tikai šajā rakstā aprakstītās problēmas novēršanai. Izmantojiet to tikai tām sistēmām, kurām ir radusies tieši šī problēma. Iespējams, tiks veikta šī labojumfaila papildu testēšana. Tādēļ, ja jums ir šī problēma nerada nopietnus traucējumus, ieteicams nogaidīt, līdz tiks izlaista nākamā servisa pakotne Microsoft Dynamics NAV 2009 vai nākamo Microsoft Dynamics NAV versiju, kurā ir iekļauts šis labojumfails.

Piezīme. Īpašos gadījumos standarta izmaksas par atbalsta zvaniem nav jāsedz, ja ar tehniskā atbalsta speciālistu programmai Microsoft Dynamics un saistītiem produktiem nosaka, ka šo problēmu novērsīs noteikts atjauninājums. Parasti atbalsta izmaksas tiek piemērotas jautājumiem par papildu atbalstu un problēmām, kas neskar specifisko atjauninājumu apspriešanu.



Informācija par instalēšanu

Microsoft piedāvā programmēšanas piemērus tikai uzskatāmībai, nesniedzot nekādas tiešas vai netiešas garantijas. Tas ietver, bet neaprobežojas ar netiešām garantijām par piemērotību pārdošanai vai atbilstību noteiktam mērķim. Šajā rakstā tiek pieņemts, ka pārzināt programmēšanas valodu, kas tiek aprakstīta, un rīkus, kas tiek izmantoti, lai izveidotu un atkļūdotu procedūras. Microsoft atbalsta inženieri var palīdzēt izskaidrot kādas noteiktas procedūras funkcionalitāti, taču viņi nemainīs šos piemērus, lai sniegtu skaidrāku funkcionalitāti, un neveidos jaunas procedūras, kas atbilstu īpašām prasībām.

Piezīme. Pirms šī labojumfaila instalēšanas pārliecinieties, vai ka visi Microsoft Navision klients lietotāji ir atteikušies sistēmu. Tas ietver Microsoft Navision lietojumprogrammu pakalpojumu (NAS) klients lietotājiem. Jums ir jābūt tikai klienta lietotājam, kurš ir pieteicies datorā, kad izmantojat šo labojumfailu.

Lai ieviestu šo labojumfailu, datorā jābūt instalētai izstrādātāja licenci.

Ieteicams, ka lietotāja konts tiek atvērts logs Windows lietotājvārdi vai logā datu bāzes lietotājvārdi piešķirt "SUPER" lomas ID. Ja lietotāja kontam nevar piešķirt "SUPER" lomas ID, ir jāpārbauda lietotāja konts ir šādas atļaujas:

  • Modificēt atļaujas objektu, kad tiks mainīts.

  • Izpildes atļaujas sistēmas objekts ID 5210 objekta un sistēmas objekts ID 9015 objektam.



Piezīme. Jums nav tiesības datu krātuvju vien lai veiktu datu labošanu.

Koda izmaiņas

Piezīme. Vienmēr pārbaudes kods novērš kontrolētā vidē pirms lietojat datoru ražošanas labojumus.
Lai novērstu šo problēmu, rīkojieties šādi:

  1. Nomainiet šo kodu globālo mainīgo sadaļā "Jaunināšanas dimensijas ieraksts - SQL" koda (104049) šādi:
    Kods

    ...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;
    ...

    Aizstāšanas kodu

    ...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;
    ...
  2. Nomainiet šo kodu "Jaunināšana dimensijas ieraksts - SQL" koda (104049) CreateTablesQry funkciju šādi:
    Kods 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;
    ...

    Aizstāšanas kods = 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;
    ...

    Kods 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
    ...

    Aizstāšanas kods 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
    ...


Priekšnosacījumi

Lai lietotu šo labojumfailu Microsoft Dynamics NAV 2013 jābūt.

Informācija par noņemšanu

Nevar noņemt šo labojumfailu.

Statuss

Korporācija Microsoft ir apstiprinājusi, ka šī problēma pastāv Microsoft produktos, kas ir minēti sadaļā "Attiecas uz".

Piezīme. Šis ir STEIDZAMI PUBLICĒJAMS raksts, kas izveidots tieši Microsoft atbalsta organizācijā. Šajā rakstā ietvertā informācija ir sniegta, reaģējot uz nesen konstatētām problēmām. Tā kā šis raksts ir tapis pieejams neilgā laikā, materiālos var būt pareizrakstības kļūdas un tās var tikt labotas jebkurā laikā bez paziņojuma. Skatīt Lietošanas citi apsvērumi.

Vai nepieciešama papildu palīdzība?

Paplašiniet savas prasmes
Iepazīties ar apmācību
Esiet pirmais, kas saņem jaunās iespējas
Pievienoties Microsoft Insider

Vai šī informācija bija noderīga?

Cik lielā mērā esat apmierināts ar valodas kvalitāti?
Kas ietekmēja jūsu pieredzi?

Paldies par jūsu atsauksmēm!

×