次の動的 SQL で複数の変換関数を取り除くにはどうすればよいですか?
IF @MediaTypeID > 0 or @MediaGroupID > 0
BEGIN
SET @SQL = @SQL + 'INNER JOIN (SELECT lmc.ID FROM Lookup_MediaChannels (nolock) lmc
INNER JOIN Lookup_SonarMediaTypes (nolock) lsmt ON lmc.SonarMediaTypeID = lsmt.ID
WHERE (ISNULL('+ CONVERT(VARCHAR(10),@MediaTypeID) +',0) = 0 OR lsmt.ID = '+ CONVERT(VARCHAR(10),@MediaTypeID) +')
AND (ISNULL('+ CONVERT(VARCHAR(10),@MediaGroupID)+',0) = 0 OR lsmt.SonarMediaGroupID = '+ CONVERT(VARCHAR(10),@MediaGroupID) +'))t ON t.ID = lmc.ID '
最初にそれらを変換して、以下のような変換呼び出しの代わりに変数を使用しようとしました
IF @MediaTypeID > 0 or @MediaGroupID > 0
BEGIN
SET @TypeID = CONVERT(VARCHAR(10),@MediaTypeID)
SET @GroupID = CONVERT(VARCHAR(10),@MediaGroupID)
SET @SQL = @SQL + 'INNER JOIN (SELECT lmc.ID FROM Lookup_MediaChannels (nolock) lmc
INNER JOIN Lookup_SonarMediaTypes (nolock) lsmt ON lmc.SonarMediaTypeID = lsmt.ID
WHERE (ISNULL('+ @TypeID +',0) = 0 OR lsmt.ID = '+ @TypeID +')
AND (ISNULL('+ @GroupID+',0) = 0 OR lsmt.SonarMediaGroupID = '+ @GroupID +'))'
END
しかし、それは私にこのエラーを与えました
メッセージ 245、レベル 16、状態 1、行 13
varchar 値 ',0) = 0 OR lsmt.ID = ' をデータ型 int に変換するときに変換に失敗しました。