動的T-SQLの一部を生成して実行するストアドプロシージャがあります。これは、一度構築されると、次のようになります。
SELECT
tblUsers.strUserName AS [Username]
,tblUsers.strEmail AS [Email]
,tblUserAuditLog.strIpAddress AS [IP Address]
,tblUserAuditLog.dtAuditTimeStamp AS [Timestamp]
,tblUserAuditLog.strAuditLogAction AS [Action]
,tblUserAuditLog.strLogDetails AS [Details]
FROM
tblUserAuditLog
LEFT OUTER JOIN tblUsers
ON tblUserAuditLog.intUserIdFK = tblUsers.intUserId
WHERE
tblUsers.strUserName = 'a12jun'
AND tblUserAuditLog.dtAuditTimeStamp >= '2012-08-10'
このクエリは、開発環境で数千行を返す可能性があり、ライブではかなり多くの行を返します。
実際に結果を返す前に、動的クエリが返す行数を確認したいので、その数が制限を超えている場合は、「クエリを絞り込む」エラーメッセージを返すことができます。
私は次のようなSQLの別の部分を生成しようとしました:
DECLARE @sqlrowcount NVARCHAR(MAX);
SET @sqlrowcount = 'SELECT COUNT(*) FROM (' + @sql + ') AS TEMP';
EXEC(@sqlrowcount);
IF @@ROWCOUNT > @limit BEGIN .... END
@sql
動的クエリはどこにありますか。次に、レコード数を値とする1つのレコードを返すため、EXEC(@sqlrowcount)
常にが返されることに恥ずかしいことに気づきました。1
たとえば、結果を一時テーブルに書き込まずに、これを行う(比較的)エレガントな方法はありますか?