我有一个使用游标的 SQL Server sp:
DECLARE TestCursor CURSOR FOR
SELECT
tblHSOutcomes.strOutcomeName,
tblHSData.fkHSTest
FROM
tblHSData
INNER JOIN tblHSOutcomes ON tblHSData.fkOutcome = tblHSOutcomes.uidOutcome
INNER JOIN tblHSTests ON tblHSData.fkHSTest = tblHSTests.uidTest
WHERE
tblHSData.fkEpisode = @uidHSEpisodes
OPEN TestCursor
FETCH NEXT FROM TestCursor
INTO @Result, @TestID
WHILE @@FETCH_STATUS = 0
BEGIN
...etc
它工作正常,但是最好能够在继续处理之前检查游标查询是否有任何记录。
是否有一个 @@
var 可以用来检查这个?
我知道有@@RowCount
- 但这只有当前处理的行数 - 所以不是很有帮助
理想情况下,我希望能够做这样的事情:
if @@cursorQueryHasRecords
BEGIN
WHILE @@FETCH_STATUS = 0
BEGIN
...etc
谢谢
最佳答案
关于sql-server - 在使用游标sql处理之前计算行数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3734682/