次のエラーが発生し続けます。
メッセージ 241、レベル 16、状態 1、行 9 文字列から日時を変換するときに変換に失敗しました。
実行しようとしているコードは次のとおりです。
DECLARE @v_sql varchar(max),
@v_database varchar(25),
@vStartTime DATETIME,
@vEndTime DATETIME
SELECT @v_database = N'[DATABASE_NAME]', @vStartTime = '2012-09-27', @vEndTime = '2012-11-27'
SELECT @v_sql = N'SELECT
(SELECT ID FROM DATASTORE.DBO.PLANT WHERE DESCRIPTION = ''Henderson''),
SEQ,
AID,
NAME,
GRP,
AREA,
PRIO,
CASE ITIME WHEN ''-'' THEN NULL ELSE CAST(SUBSTRING(ITIME,1,8) + '' '' + SUBSTRING(ITIME,9,2) + '':'' + SUBSTRING(ITIME,11,2) + '':'' + SUBSTRING(ITIME,13,2) AS DATETIME) END ITIME,
CASE ATIME WHEN ''-'' THEN NULL ELSE CAST(SUBSTRING(ATIME,1,8) + '' '' + SUBSTRING(ATIME,9,2) + '':'' + SUBSTRING(ATIME,11,2) + '':'' + SUBSTRING(ATIME,13,2) AS DATETIME) END ATIME,
CASE NTIME WHEN ''-'' THEN NULL ELSE CAST(SUBSTRING(NTIME,1,8) + '' '' + SUBSTRING(NTIME,9,2) + '':'' + SUBSTRING(NTIME,11,2) + '':'' + SUBSTRING(NTIME,13,2) AS DATETIME) END NTIME,
DUR,
MSG,
VAR1,
VAR2,
VAR3,
VAR4,
OPR,
USER_COMMENT
FROM ' + @v_database + '.PROD.ALARM
WHERE CAST(substring(ITIME, 1, 4) + ''-'' + substring(ITIME, 5, 2) + ''-'' + substring(ITIME, 7, 2) + '' '' + substring(ITIME,9,2) + '':'' + substring(ITIME,11,2) + '':'' + substring(ITIME,13,2) + substring(ITIME,15,3) AS DATETIME) BETWEEN ' + @vStartTime +' AND ' + @vEndTime + ' ORDER BY ITIME'
EXEC(@v_sql)
私は同僚のためにこれを調べていますが、私たち二人とも困惑しています。
もう少し掘り下げて編集sp_executesql
すると、パラメーターを次のように渡して、自分で解決できました。
declare
@vSql NVARCHAR(MAX),
@vParam NVARCHAR(MAX),
@vDatabase VARCHAR(15)
SET @vParam = '@vStartTime DATETIME, @vEndTime DATETIME'
SELECT @vSql = '
SELECT ''
'+ @vDatabase + ''',
ITEM_CODE,
SOURCE,
DEST,
TRAN_DT,
MILL_NAME,
NULL
FROM ' + @vDatabase + '.PROD.GRD_LOG
WHERE TRAN_DT BETWEEN @vStartTime AND @vEndTime'
EXEC sp_executesql @vSql, @vParam, @vStartTime, @vEndTime
変数を作成し、変数を実行する代わりにNVARCHAR(MAX)
使用することで、問題を解決できました。sp_executesql
@vSql
これを調べていた人に感謝します。