sql >> Database teknologi >  >> RDS >> Sqlserver

Sammenkæd databasenavnet i en SQL multipart identifikator

Du skal bruge dynamisk sql for at gøre sådan noget.

declare @sql nvarchar(max);
declare @params nvarchar(max);

set @params= N'@pNrodcto int, @pTipodcto int, @pUsuario int, @pEmpresa char(20)';

set @sql = N'INSERT INTO CONTROL_LOGISTICA.dbo.ITEMS_TRAMITE (NRODCTO, TIPODCTO, PRODUCTO, EMPRESA, CODUSUARIO, CODUBICA, CANTIDAD, CCHECK_HIJO) 
  SELECT @pNrodcto,@pTipodcto,M.PRODUCTO,@pEmpresa,@pUsuario,M.CODUBICA,M.CANTIDAD,0
  FROM '+db_name(db_id(@pEmpresa))+'.dbo.MVTRADE M WITH(NOLOCK) --Here im stuck
  INNER JOIN Dbo.vReporteMercia_ESP P ON P.PRODUCTO = M.PRODUCTO
  WHERE M.CANTIDAD <> 0 AND M.Origen = ''FAC'' 
  AND M.NRODCTO = @pNrodcto AND M.TIPODCTO = @pTipodcto';
exec sp_executesql @sql, @params, @pNrodcto, @pTipodcto, @pUsuario, @pEmpresa;

For at undgå direkte sammenkædning af en parameter til en eksekveret sql-streng, pakkede jeg parameteren ind i kald til db_name() og db_id() . Dette ville returnere null for et ugyldigt databasenavn, men ville ikke forhindre nogen i at henvise til en database, du ikke vil have dem til. Overvej at sammenligne parameterværdien med en hvidliste.

Reference:



  1. ændre størrelsen på datatype i sql

  2. Sequel Pro og MySQL forbindelse mislykkedes

  3. Overvågning af tilgængelighed Gruppereplikasynkronisering

  4. En bedre måde at generere dette json-array fra MySql-data med php