sql-server - SQL OpenQuery 字符串附近的语法不正确

标签 sql-server t-sql openquery

我正在尝试在存储过程中运行以下查询。当我尝试使用硬编码值而不是变量运行它时,它运行良好。但就在我尝试将整个查询封装到一个变量中并执行它时,它给了我一个错误:“FIFO”附近的语法不正确。

我尝试用双引号替换单引号,但没有用。请帮忙!

DECLARE @TSQL nvarchar(max); Declare @STATION_CODE varchar(max); Declare @STATION_CODE_PREV varchar(max);

SET @STATION_CODE='1600020'; SET @STATION_CODE_PREV='1600007'; SET @TSQL='SELECT * FROM OPENQUERY (VFDB,''SELECT COUNT(TABLE_7.FIFO) AS FIFO_COUNT,TABLE_7.FIFO,TABLE_7.Day_Hour ,TABLE_7.Station_Code,''FIFO'' AS Element FROM  ( select CAST(CASE WHEN TABLE_6 .BCD_PRV2_EXIT=TABLE_5 .BCD_PRV2 THEN ''1'' ELSE ''0'' END AS INT) FIFO,    case when datepart(hour,TABLE_6.CREATION_DATE_E3 )<10 
      then
    ''0''
      +Right (Cast(datepart(hour,TABLE_6.CREATION_DATE_E3 + 100) As Varchar) ,2)+'':00 - ''+''0''
      +Right(Cast(datepart(hour,TABLE_6.CREATION_DATE_E3 + 100) As Varchar) ,2)+'':59'' 
        else

       Right (Cast(datepart(hour,TABLE_6.CREATION_DATE_E3 + 100) As Varchar) ,2)+'':00 - ''
      +Right(Cast(datepart(hour,TABLE_6.CREATION_DATE_E3 + 100) As Varchar) ,2)+'':59''

      end As Day_Hour ,TABLE_6.Station_Code As Station_Code  from

        (           select T1_ENTRY.RANK1_ENTRY AS T5_R1, T1_ENTRY.BCD_PRV1,T1_ENTRY.CREATION_DATE_E1,T2_ENTRY.RANK2_ENTRY , T2_ENTRY.BCD_PRV2 ,T2_ENTRY.CREATION_DATE_E2           from 
                (
                select MFG_UNIT_NUM as BCD_PRV1,CREATION_DATE AS CREATION_DATE_E1 ,ROW_NUMBER()over(order by Creation_Date) as RANK1_ENTRY
                FROM dbo.DAW_FN_STATS_TLDTLRAW(115, ''REFRIGERATOR'', NULL, '''''+ @STATION_CODE +''''', NULL,Dateadd(HOUR, Datediff(HOUR,0,GETDATE()),0),Dateadd(hh,1, Dateadd(HOUR, Datediff(HOUR,0,GETDATE()),0)))RAWDTL 
                ) T1_ENTRY          LEFT JOIN   
                (
                select MFG_UNIT_NUM as BCD_PRV2,CREATION_DATE AS CREATION_DATE_E2,ROW_NUMBER()over(order by Creation_Date) as RANK2_ENTRY
                FROM dbo.DAW_FN_STATS_TLDTLRAW(115, ''REFRIGERATOR'', NULL, '''''+ @STATION_CODE_PREV +''''', NULL,Dateadd(HOUR, Datediff(HOUR,0,GETDATE()),0),Dateadd(hh,1, Dateadd(HOUR, Datediff(HOUR,0,GETDATE()),0)))RAWDTL 
                ) T2_ENTRY          ON T1_ENTRY.RANK1_ENTRY=T2_ENTRY.RANK2_ENTRY-1
        ) TABLE_5

LEFT JOIN 

        (       select T3_EXIT.RANK1_EXIT AS T6_R1, T3_EXIT.BCD_PRV1_EXIT,T3_EXIT.CREATION_DATE_E3,T4_EXIT.RANK2_EXIT , T4_EXIT.BCD_PRV2_EXIT ,T4_EXIT.CREATION_DATE_E4,T3_EXIT.Station_Code            from 
                (
                select MFG_UNIT_NUM as BCD_PRV1_EXIT,CREATION_DATE AS CREATION_DATE_E3 ,ROW_NUMBER()over(order by Creation_Date) as RANK1_EXIT,STATION_CODE as STATION_CODE 
                FROM dbo.DAW_FN_STATS_TLDTLRAW(115,''REFRIGERATOR'', NULL, '''+@STATION_CODE+''',NULL,Dateadd(HOUR, Datediff(HOUR,0,GETDATE()),0),Dateadd(hh,1, Dateadd(HOUR, Datediff(HOUR,0,GETDATE()),0)))RAWDTL
                ) T3_EXIT           LEFT JOIN   
                (
                select MFG_UNIT_NUM as BCD_PRV2_EXIT,CREATION_DATE AS CREATION_DATE_E4,ROW_NUMBER()over(order by Creation_Date) as RANK2_EXIT,STATION_CODE as STATION_CODE 
                FROM dbo.DAW_FN_STATS_TLDTLRAW(115,''REFRIGERATOR'', NULL,'''+@STATION_CODE_PREV+''', NULL,Dateadd(HOUR, Datediff(HOUR,0,GETDATE()),0),Dateadd(hh,1, Dateadd(HOUR, Datediff(HOUR,0,GETDATE()),0)))RAWDTL
                        ) T4_EXIT           ON T3_EXIT.RANK1_EXIT=T4_EXIT.RANK2_EXIT-1       ) TABLE_6 ON TABLE_5.BCD_PRV2=TABLE_6.BCD_PRV2_EXIT   )TABLE_7 GROUP BY  TABLE_7.FIFO,TABLE_7.Day_Hour ,Table_7. STATION_CODE'')';

EXEC sp_executesql @TSQL;

最佳答案

您已经得到了答案,所以这只是一个提示,您将来如何轻松解决此类问题。

declare @sql_string varchar(100)
set @sql_string = 'SELECT * FROM OPENQUERY (VFDB,''SELECT * FROM foo WHERE bar = ''''i am a string'''';'')' 
select @sql_string --> This here will let you see how your string looks like

关于sql-server - SQL OpenQuery 字符串附近的语法不正确,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32524965/

相关文章:

sql-server - 同一驱动器上的数据库和事务日志会导致问题吗?

sql-server - 如何通过 TSQL 从 SQL Server 查询中生成 JSON 字符串?

sql - 对字段进行分组以提供某个范围内的值计数

PHP/SQL 将值插入表并将一个值设置为唯一后,无法插入更多值

SQL查询源代码

sql-server - 列名和/或表名作为参数

sql - 在 T-SQL 中,当另一行 <> 'X' 时检索最新日期的一行数据

openquery - 如何克服 "Failure getting record lock on a record from table"?

sql-server-2008 - Lotus Domino NotesSQL ODBC 和 SQL 2008 查询