sp_attach_single_file_db (Transact-SQL)
S'applique à : SQL Server
Joint une base de données qui n’est qu’un seul fichier de données au serveur actuel. sp_attach_single_file_db
ne peut pas être utilisé avec plusieurs fichiers de données.
Important
Cette fonctionnalité sera supprimée dans une version future de 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 CREATE DATABASE <database_name> FOR ATTACH
à la place. Pour plus d’informations, consultez CREATE DATABASE. N’utilisez pas cette procédure sur une base de données répliquée.
N’attachez pas ou ne restaurez pas de bases de données à partir 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 autre qu’un serveur de production 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.
Conventions de la syntaxe Transact-SQL
Syntaxe
sp_attach_single_file_db
[ @dbname = ] N'dbname'
, [ @physname = ] N'physname'
[ ; ]
Arguments
[ @dbname = ] N’dbname'
Nom de la base de données à attacher au serveur. @dbname est sysname, sans valeur par défaut.
[ @physname = ] N’physname'
Nom physique, y compris le chemin d’accès, du fichier de base de données. @physname est nvarchar(260), sans valeur par défaut.
Cet argument est mappé au FILENAME
paramètre de l’instruction CREATE DATABASE
. Pour plus d’informations, consultez CREATE DATABASE.
Remarque
Lorsque vous attachez une base de données SQL Server 2005 (9.x) qui contient des fichiers catalogue de texte intégral sur une instance de serveur plus récente de SQL Server, les fichiers catalogue sont attachés à partir de leur emplacement précédent, ainsi que les autres fichiers de base de données, identiques à ceux de SQL Server 2005 (9.x). Pour plus d’informations, consultez Mise à niveau de la fonction de recherche en texte intégral.
Valeurs des codes de retour
0
(réussite) or 1
(échec).
Jeu de résultats
Aucune.
Notes
Utilisez sp_attach_single_file_db
uniquement sur les bases de données précédemment détachées du serveur à l’aide d’une opération explicite sp_detach_db
ou sur des bases de données copiées.
sp_attach_single_file_db
fonctionne uniquement sur les bases de données qui ont un seul fichier journal. Lorsque sp_attach_single_file_db
vous attachez la base de données au serveur, elle génère un nouveau fichier journal. Si la base de données est en lecture seule, le journal est créé au même endroit que le précédent.
Remarque
Une capture instantanée de base de données ne peut pas être détachée ni attachée.
N’utilisez pas cette procédure sur une base de données répliquée.
autorisations
Pour plus d’informations sur la façon dont les autorisations sont gérées lorsqu’une base de données est attachée, consultez CREATE DATABASE.
Exemples
Dans l'exemple suivant, AdventureWorks2022
est détaché, puis un des fichiers d'AdventureWorks2022
est attaché au serveur actif.
USE master;
GO
EXEC sp_detach_db @dbname = 'AdventureWorks2022';
EXEC sp_attach_single_file_db @dbname = 'AdventureWorks2022',
@physname =
N'C:\Program Files\Microsoft SQL Server\MSSQL13.MSSQLSERVER\MSSQL\Data\AdventureWorks2022_Data.mdf';