Compartir por


sp_dropmessage (Transact-SQL)

Se aplica a: SQL Server

Quita un mensaje de error definido por el usuario especificado de una instancia del Motor de base de datos de SQL Server. Los mensajes definidos por el usuario se pueden ver mediante la vista de sys.messages catálogo.

Convenciones de sintaxis de Transact-SQL

Sintaxis

sp_dropmessage
    [ [ @msgnum = ] msgnum ]
    [ , [ @lang = ] N'lang' ]
[ ; ]

Argumentos

[ @msgnum = ] msgnum

Número de mensaje que se va a quitar. @msgnum es int, con un valor predeterminado de NULL. @msgnum debe ser un mensaje definido por el usuario que sea un número de mensaje mayor que 50000 (50 000).

[ @lang = ] N'lang'

Idioma del mensaje que se va a quitar. @lang es sysname, con un valor predeterminado de NULL. Si all se especifica , se quitan todas las versiones de idioma de @msgnum .

Valores de código de retorno

0 (correcto) o 1 (erróneo).

Conjunto de resultados

Ninguno.

Permisos

Requiere la pertenencia a los roles fijos de servidor sysadmin y serveradmin .

Comentarios

A menos que all se especifique para @lang, todas las versiones localizadas de un mensaje deben quitarse antes de que se pueda quitar la versión en inglés de EE. UU. del mensaje.

Ejemplos

A Quitar un mensaje definido por el usuario

En el ejemplo siguiente se quita un mensaje definido por el usuario, el número 50001, de sys.messages.

USE master;
GO
EXEC sp_dropmessage 50001;

B. Quitar un mensaje definido por el usuario que incluya una versión localizada

En el ejemplo siguiente se agrega un mensaje definido por el usuario, el número 60000, que incluye una versión localizada y, a continuación, quita ambas variaciones del mensaje.

USE master;
GO

-- Create a user-defined message in U.S. English
EXEC sp_addmessage
    @msgnum = 60000,
    @severity = 16,
    @msgtext = N'The item named %s already exists in %s.',
    @lang = 'us_english';

-- Create a localized version of the same message.
EXEC sp_addmessage
    @msgnum = 60000,
    @severity = 16,
    @msgtext = N'L''élément nommé %1! existe déjà dans %2!',
    @lang = 'French';
GO

-- This statement will fail as long as the localized version
-- of the message exists.
EXEC sp_dropmessage 60000;
GO

-- This statement will drop the message.
EXEC sp_dropmessage @msgnum = 60000,
    @lang = 'all';
GO

C. Quitar una versión localizada de un mensaje definido por el usuario

En el ejemplo siguiente se quita una versión traducida de un mensaje definido por el usuario, el número 60000, sin quitar todo el mensaje.

USE master;
GO

-- Create a user-defined message in U.S. English
EXEC sp_addmessage
    @msgnum = 60000,
    @severity = 16,
    @msgtext = N'The item named %s already exists in %s.',
    @lang = 'us_english';

-- Create a localized version of the same message.
EXEC sp_addmessage
    @msgnum = 60000,
    @severity = 16,
    @msgtext = N'L''élément nommé %1! existe déjà dans %2!',
    @lang = 'French';
GO

-- This statement will remove only the localized version of the
-- message.
EXEC sp_dropmessage
    @msgnum = 60000,
    @lang = 'French';
GO