Attacher une base de données
Cette rubrique explique comment attacher une base de données dans SQL Server 2012 à l'aide de SQL Server Management Studio ou de Transact-SQL. Vous pouvez utiliser cette fonctionnalité pour copier, déplacer, ou mettre à niveau une base de données SQL Server.
Dans cette rubrique
Avant de commencer :
Conditions préalables
Recommandations
Sécurité
Pour attacher une base de données, utilisez :
SQL Server Management Studio
Transact-SQL
Suivi : Après la mise à niveau d'une base de données
Avant de commencer
Conditions préalables
La base de données doit d'abord être détachée. Toute tentative d'attachement d'une base de données qui n'a pas été détachée retourne une erreur. Pour plus d'informations, consultez Détacher une base de données.
Lorsque vous attachez une base de données, tous les fichiers de données (fichiers MDF et NDF) doivent être disponibles. Si un fichier de données possède un chemin différent de celui qui existait lorsque la base de données a été créée pour la première fois ou attachée pour la dernière fois, vous devez spécifier le chemin actuel du fichier.
Recommandations
Nous vous recommandons de déplacer les bases de données à l'aide de la procédure de déplacement planifié ALTER DATABASE, plutôt qu'à l'aide de la méthode de détachement et d'attachement. Pour plus d'informations, consultez Déplacer des bases de données utilisateur.
[Haut de la page]
Sécurité
Les autorisations d'accès au fichier sont définies au cours de plusieurs opérations de base de données, notamment le détachement ou l'attachement d'une base de données. Pour plus d'informations sur les autorisations de fichier définies lors du détachement et de l'attachement d'une base de données, consultez Sécurisation des fichiers de données et des fichiers journaux dans la documentation en ligne de SQL Server 2008 R2.
Nous vous recommandons de ne pas attacher ni restaurer de bases de données provenant de sources inconnues ou non approuvées. Ces bases de données peuvent contenir du code malveillant susceptible d'exécuter du code Transact-SQL indésirable ou de provoquer des erreurs en modifiant le schéma ou la structure physique des bases de données. Avant d'utiliser une base de données issue d'une source inconnue ou non approuvée, exécutez DBCC CHECKDB sur la base de données sur un serveur non productif et examinez également le code, notamment les procédures stockées ou le code défini par l'utilisateur, de la base de données. Pour plus d'informations sur la façon de joindre des bases de données et des informations à propos des modifications apportées aux métadonnées lorsque vous joignez une base de données, consultez Attacher et détacher une base de données (SQL Server).
Autorisations
L'autorisation CREATE DATABASE, CREATE ANY DATABASE ou ALTER ANY DATABASE est obligatoire.
[Haut de la page]
Utilisation de SQL Server Management Studio
Pour attacher une base de données
Dans l'Explorateur d'objets SQL Server Management Studio, connectez-vous à une instance du Moteur de base de données SQL Server, puis développez-la.
Cliquez avec le bouton droit sur Bases de données, puis cliquez sur Attacher.
Dans la boîte de dialogue Attacher des bases de données, pour spécifier la base de données à attacher, cliquez sur Ajouter, dans la boîte de dialogue Rechercher les fichiers de base de données, sélectionnez l'unité de disque contenant la base de données et développez l'arborescence pour rechercher et sélectionner le fichier .mdf de la base de données. Par exemple :
C:\Program Files\Microsoft SQL Server\MSSQL11.MSSQLSERVER\MSSQL\DATA\AdventureWorks2012_Data.mdf
Important
Une tentative de sélection d'une base de données déjà attachée génère une erreur.
Bases de données à attacher
Affiche des informations sur les bases de données sélectionnées.<aucun en-tête de colonne>
Affiche une icône indiquant l'état de l'opération d'attachement. Les icônes possibles sont décrites dans la section État ci-dessous.Emplacement du fichier MDF
Affiche le chemin d'accès et le nom du fichier MDF sélectionné.Nom de la base de données
Affiche le nom de la base de données.Attacher en tant que
Permet de spécifier éventuellement un autre nom sous lequel la base de données doit être attachée.Propriétaire
Fournit une liste déroulante des propriétaires de bases de données possibles dans laquelle vous pouvez sélectionner un autre propriétaire.État
Affiche l'état de la base de données conformément au tableau ci-après.Icône
Texte d'état
Description
(Aucune icône)
(Aucun texte)
L'opération d'attachement n'a pas démarré ou est peut-être en attente pour cet objet. Il s'agit de la valeur par défaut lorsque la boîte de dialogue est ouverte.
Triangle vert dirigé vers la droite
En cours
L'opération d'attachement a démarré, mais n'est pas terminée.
Coche verte
Réussi
L'attachement de l'objet a réussi.
Cercle rouge contenant une croix blanche
Erreur
L'opération d'attachement a rencontré une erreur et ne s'est pas terminée correctement.
Cercle contenant deux quartiers noirs (à gauche et à droite) et deux quartiers blancs (en haut et en bas)
Arrêté
L'opération d'attachement n'a pas réussi, car l'utilisateur l'a interrompue.
Cercle contenant une flèche courbe pointant dans le sens inverse des aiguilles d'une montre
Restauré
L'opération d'attachement a réussi, mais a été restaurée en raison d'une erreur lors de l'attachement d'un autre objet.
Message
Affiche un message vierge ou un lien hypertexte « Fichier introuvable ».Ajouter
Permet de rechercher les principaux fichiers de base de données nécessaires. Lorsque l'utilisateur sélectionne un fichier .mdf, les informations applicables sont automatiquement remplies dans les champs respectifs de la grille Bases de données à attacher.Supprimer
Supprime le fichier sélectionné de la grille Bases de données à attacher.Détails de la base de données « ** <database_name> ** »
Affiche le nom des fichiers à attacher. Pour vérifier ou modifier le nom du chemin d'accès d'un fichier, cliquez sur le bouton Parcourir (…).[!REMARQUE]
Si un fichier n'existe pas, la colonne Message affiche « Introuvable ». Si un fichier journal est introuvable, cela signifie qu'il se trouve dans un autre répertoire ou qu'il a été supprimé. Vous devez mettre à jour le chemin d'accès du fichier dans la grille Détails de la base de données pour désigner l'emplacement correct ou supprimer le fichier journal de la grille. Si un fichier de données .ndf est introuvable, vous devez mettre à jour son chemin d'accès dans la grille pour désigner l'emplacement correct.
Nom du fichier d'origine
Affiche le nom du fichier attaché appartenant à la base de données.Type de fichier
Indique le type du fichier (Données ou Journal).Chemin d'accès au fichier actuel
Affiche le chemin d'accès au fichier de base de données sélectionné. Le chemin d'accès peut être modifié manuellement.Message
Affiche un message vierge ou un lien hypertexte « Fichier introuvable ».
[Haut de la page]
Utilisation de Transact-SQL
Pour attacher une base de données
Connectez-vous au Moteur de base de données.
Dans la barre d'outils standard, cliquez sur Nouvelle requête.
Utilisez l'instruction CREATE DATABASE avec la clause FOR ATTACH.
Copiez et collez l'exemple suivant dans la fenêtre de requête, puis cliquez sur Exécuter. Cet exemple attache les fichiers de la base de données AdventureWorks2012 et renomme la base de données MyAdventureWorks.
CREATE DATABASE MyAdventureWorks ON (FILENAME = 'C:\MySQLServer\AdventureWorks_Data.mdf'), (FILENAME = 'C:\MySQLServer\AdventureWorks_Log.ldf') FOR ATTACH;
[!REMARQUE]
Vous pouvez également utiliser la procédure stockée sp_attach_db ou sp_attach_single_file_db. Toutefois, ces procédures seront supprimées dans une future version de Microsoft SQL Server. Évitez d'utiliser cette fonctionnalité dans de nouveaux travaux de développement, et prévoyez de modifier les applications qui utilisent actuellement cette fonctionnalité. Nous vous recommandons d'utiliser plutôt CREATE DATABASE … FOR ATTACH.
[Haut de la page]
Suivi : Après la mise à niveau d'une base de données SQL Server
Après avoir mis à niveau une base de données à l'aide de la méthode par attachement, cette base de données est immédiatement disponible et est automatiquement mise à niveau. Si la base de données comprend des index de recherche en texte intégral, la mise à niveau les importe, les réinitialise ou les reconstruit, selon le paramètre de la propriété de serveur Option de mise à niveau des index de recherche en texte intégral. Si l'option de mise à niveau a la valeur Importer ou Reconstruire, les index de recherche en texte intégral ne seront pas disponibles pendant la mise à niveau. Selon le volume de données indexé, l'importation peut prendre plusieurs heures et la reconstruction jusqu'à dix fois plus longtemps. Notez également que lorsque l'option de mise à niveau est Importer, si un catalogue de texte intégral n'est pas disponible, les index de recherche en texte intégral associés sont reconstruits.
Si le niveau de compatibilité d'une base de données utilisateur était à 90 ou 100 avant la mise à niveau, il reste le même après la mise à niveau. Si le niveau de compatibilité était à 80 ou moins avant la mise à niveau, dans la base de données mise à niveau, le niveau de compatibilité est défini à 90, ce qui correspond au niveau de compatibilité le plus bas pris en charge dans SQL Server 2012. Pour plus d'informations, consultez Niveau de compatibilité ALTER DATABASE (Transact-SQL).
[Haut de la page]
Voir aussi
Référence
CREATE DATABASE (Transact-SQL)