OBJECT_ID (Transact-SQL)

Se aplica a:SQL ServerAzure SQL DatabaseAzure SQL Managed InstanceAzure Synapse AnalyticsAnalytics Platform System (PDW)

Devuelve el número de Id. del objeto de base de datos de un objeto de ámbito de esquema.

Importante

Los objetos que no están en el ámbito del esquema, por ejemplo los desencadenadores DDL, no se pueden consultar utilizando OBJECT_ID. En el caso de objetos que no están en la vista de catálogo sys.objects, debe obtener los números de identificación de objeto mediante consultas realizadas a la vista de catálogo correspondiente. Por ejemplo, para devolver el número de identificación de objeto de un desencadenador DDL, use SELECT OBJECT_ID FROM sys.triggers WHERE name = 'DatabaseTriggerLog``'.

Convenciones de sintaxis de Transact-SQL

Sintaxis

OBJECT_ID ( '[ database_name . [ schema_name ] . | schema_name . ]   
  object_name' [ ,'object_type' ] )  

Nota:

Para ver la sintaxis de Transact-SQL para SQL Server 2014 (12.x) y versiones anteriores, consulte Versiones anteriores de la documentación.

Argumentos

'object_name'
Es el objeto que va a utilizarse. object_name es varchar o nvarchar. Si object_name es varchar, se convierte implícitamente a nvarchar. Especificar los nombres de la base de datos y del esquema es opcional.

'object_type'
Es el tipo de objeto de ámbito del esquema. object_type es varchar o nvarchar. Si object_type es varchar, se convierte implícitamente en nvarchar. Para ver una lista de tipos de objeto, eche un vistazo a la columna type en sys.objects (Transact-SQL).

Tipos de valor devuelto

int

Excepciones

Para un índice espacial, OBJECT_ID devuelve NULL.

Devuelve NULL si se produce un error.

Un usuario solo puede ver los metadatos de elementos protegibles que posea o para los que se le haya concedido permiso. Esto significa que las funciones integradas de emisión de metadatos, como OBJECT_ID, pueden devolver NULL si el usuario no tiene ningún permiso para el objeto. Para obtener más información, consulte Metadata Visibility Configuration.

Comentarios

Cuando el parámetro de una función del sistema es opcional, se asumen la base de datos, el equipo host, el usuario del servidor o el usuario de la base de datos actuales. Las funciones integradas siempre deben ir seguidas de paréntesis.

Cuando se especifica un nombre de tabla temporal, el nombre de base de datos debe ir antes del nombre de tabla temporal, a menos que la base de datos temporal sea tempdb. Por ejemplo: SELECT OBJECT_ID('tempdb..#mytemptable').

Las funciones del sistema se pueden usar en la lista de selección, en la cláusula WHERE y en cualquier lugar donde se permita una expresión. Para más información, vea Expresiones (Transact-SQL) y WHERE (Transact-SQL).

Ejemplos

A. Devolver el identificador de objeto de un objeto especificado

En el ejemplo siguiente se devuelve el id. de objeto de la tabla Production.WorkOrder de la base de datos AdventureWorks2022.

USE master;  
GO  
SELECT OBJECT_ID(N'AdventureWorks2022.Production.WorkOrder') AS 'Object ID';  
GO  

B. Comprobar la existencia de un objeto

En el ejemplo siguiente se comprueba la existencia de una tabla especificada comprobando si la tabla tiene un identificador de objeto. Si la tabla existe, se elimina. Si la tabla no existe, la instrucción DROP TABLE no se ejecuta.

USE AdventureWorks2022;  
GO  
IF OBJECT_ID (N'dbo.AWBuildVersion', N'U') IS NOT NULL  
DROP TABLE dbo.AWBuildVersion;  
GO  

C. Usar OBJECT_ID para especificar el valor de un parámetro de función del sistema

En el ejemplo siguiente se devuelve información de todos los índices y particiones de la tabla Person.Address en la base de datos AdventureWorks2022 con la función sys.dm_db_index_operational_stats.

Nota:

El grupo de SQL sin servidor no admite esta sintaxis en Azure Synapse Analytics.

Importante

Cuando utilice las funciones DB_ID y OBJECT_ID de Transact-SQL para devolver un valor de parámetro, asegúrese de que siempre se devuelva un Id. válido. Si el nombre de objeto o base de datos no se puede encontrar, por ejemplo, cuando no existe o se ha escrito incorrectamente, las dos funciones devolverán NULL. La función sys.dm_db_index_operational_stats interpreta NULL como un valor de carácter comodín que especifica todas las bases de datos o todos los objetos. Puesto que ésta puede ser una operación accidental, los ejemplos de esta sección demuestran una forma segura para determinar los Id. de bases de datos y objetos.

DECLARE @db_id INT;  
DECLARE @object_id INT;  
SET @db_id = DB_ID(N'AdventureWorks2022');  
SET @object_id = OBJECT_ID(N'AdventureWorks2022.Person.Address');  
IF @db_id IS NULL   
  BEGIN;  
    PRINT N'Invalid database';  
  END;  
ELSE IF @object_id IS NULL  
  BEGIN;  
    PRINT N'Invalid object';  
  END;  
ELSE  
  BEGIN;  
    SELECT * FROM sys.dm_db_index_operational_stats(@db_id, @object_id, NULL, NULL);  
  END;  
GO  

Ejemplos: Azure Synapse Analytics y Sistema de la plataforma de análisis (PDW)

D. Devolver el identificador de objeto de un objeto especificado

En el ejemplo siguiente se devuelve el id. de objeto de la tabla FactFinance de la base de datos AdventureWorksPDW2022.

SELECT OBJECT_ID('AdventureWorksPDW2012.dbo.FactFinance') AS 'Object ID';  

Consulte también

Funciones de metadatos (Transact-SQL)
sys.objects (Transact-SQL)
sys.dm_db_index_operational_stats (Transact-SQL)
OBJECT_DEFINITION (Transact-SQL)
OBJECT_NAME (Transact-SQL)