Simptom:

Când încercați să atașați o bază de date .MDF în SQL Server, vedeți următorul mesaj de eroare:

Nu s-au putut prelua datele pentru această solicitare. (Microsoft.SqlServer.Management.Sdk.Sfc)

A apărut o excepție în timpul executării unei instrucțiuni Transact-SQL sau a unui lot. (Microsoft.SqlServer.ConnectionInfo)

xxx.mdf nu este un fișier de bază de date principal. (Microsoft SQL Server, Eroare: 5171)

unde 'xxx.mdf este numele fișierului MDF de atașat.

Captură de ecran a mesajului de eroare:

Explicație precisă:

Datele din fișierul MDF sunt stocate ca pagini, fiecare pagină are 8 KB. Prima pagină se numește pagina antet fișier, care conține most informații importante despre întregul fișier, cum ar fi semnătura fișierului, dimensiunea fișierului, compatibilitatea etc. Paginile rămase conțin, de asemenea, informații importante, inclusiv informațiile despre alocarea paginilor, precum și datele reale.

Dacă pagina antetului fișierului MDF sau alte pagini importante de gestionare sunt deteriorate sau corupte și nu pot fi recunoscute de Microsoft SQL Server, Apoi SQL Server va crede că întregul fișier nu este un fișier de bază de date primar valid și va raporta această eroare.

Puteți folosi produsul nostru DataNumen SQL Recovery pentru a recupera datele din fișierul MDF corupt și a rezolva această eroare.

Exemple de fișiere:

Exemplu de fișiere MDF corupte care vor cauza eroarea:

SQL Server versiune Fișier MDF corupt Fișier MDF remediat de DataNumen SQL Recovery
SQL Server 2005 Eroare1_1.mdf Eroare1_1_fixed.mdf
SQL Server 2008 R2 Eroare1_2.mdf Eroare1_2_fixed.mdf
SQL Server 2012 Eroare1_3.mdf Eroare1_3_fixed.mdf
SQL Server 2014 Eroare1_4.mdf Eroare1_4_fixed.mdf