tipos - ¿Cómo establecer el nombre de la tabla en la consulta SQL dinámica?
substring sql (3)
Prueba esto:
/* Variable Declaration */
DECLARE @EmpID AS SMALLINT
DECLARE @SQLQuery AS NVARCHAR(500)
DECLARE @ParameterDefinition AS NVARCHAR(100)
DECLARE @TableName AS NVARCHAR(100)
/* set the parameter value */
SET @EmpID = 1001
SET @TableName = ''tblEmployees''
/* Build Transact-SQL String by including the parameter */
SET @SQLQuery = ''SELECT * FROM '' + @TableName + '' WHERE EmployeeID = @EmpID''
/* Specify Parameter Format */
SET @ParameterDefinition = ''@EmpID SMALLINT''
/* Execute Transact-SQL String */
EXECUTE sp_executesql @SQLQuery, @ParameterDefinition, @EmpID
Quiero establecer el nombre de la tabla en una consulta SQL dinámica. Intenté con éxito para el parámetro de la siguiente manera:
/* Using sp_executesql */
/* Build and Execute a Transact-SQL String with a single parameter
value Using sp_executesql Command */
/* Variable Declaration */
DECLARE @EmpID AS SMALLINT
DECLARE @SQLQuery AS NVARCHAR(500)
DECLARE @ParameterDefinition AS NVARCHAR(100)
/* set the parameter value */
SET @EmpID = 1001
/* Build Transact-SQL String by including the parameter */
SET @SQLQuery = ''SELECT * FROM tblEmployees WHERE EmployeeID = @EmpID''
/* Specify Parameter Format */
SET @ParameterDefinition = ''@EmpID SMALLINT''
/* Execute Transact-SQL String */
EXECUTE sp_executesql @SQLQuery, @ParameterDefinition, @EmpID
Ahora quiero tomar TABLE NAME
dinámicamente con un parámetro, pero no lo hice. Por favor guíame.
Para ayudar a protegerme contra la inyección de SQL, normalmente trato de usar funciones siempre que sea posible. En este caso, podrías hacer:
...
SET @TableName = ''<[db].><[schema].>tblEmployees''
SET @TableID = OBJECT_ID(TableName) --won''t resolve if malformed/injected.
...
SET @SQLQuery = ''SELECT * FROM '' + OBJECT_NAME(@TableID) + '' WHERE EmployeeID = @EmpID''
Los nombres de tabla no se pueden suministrar como parámetros, por lo que deberá construir la cadena SQL manualmente de esta manera:
SET @SQLQuery = ''SELECT * FROM '' + @TableName + '' WHERE EmployeeID = @EmpID''
Sin embargo, asegúrese de que su aplicación no permita que un usuario ingrese directamente el valor de @TableName
, ya que esto haría que su consulta sea susceptible a la inyección de SQL. Para una posible solución a esto, vea esta respuesta .