SQLSERVER存储过程中如何读出当前记录某一列的值?
其实主要是如何定位到当前行?

解决方案 »

  1.   

    看你的表结构,如果有主键id可以这样:
    定位第10行
    select top 10 id into tmp from Table
    select id from tmp where id not in(select top 9 id from tmp)
      

  2.   

    我想用cursor来操作.有哪位有这方面的资料吗?
     
      

  3.   

    请楼主参考declare cursor帮助.下面摘自DECLARE CURSOR帮助中的例子:
    下例显示如何嵌套游标以生成复杂的报表。为每个作者声明内部游标。SET NOCOUNT ONDECLARE @au_id varchar(11), @au_fname varchar(20), @au_lname varchar(40),
       @message varchar(80), @title varchar(80)PRINT '-------- Utah Authors report --------'DECLARE authors_cursor CURSOR FOR 
    SELECT au_id, au_fname, au_lname
    FROM authors
    WHERE state = 'UT'
    ORDER BY au_idOPEN authors_cursorFETCH NEXT FROM authors_cursor 
    INTO @au_id, @au_fname, @au_lnameWHILE @@FETCH_STATUS = 0
    BEGIN
       PRINT ' '
       SELECT @message = '----- Books by Author: ' + 
          @au_fname + ' ' + @au_lname   PRINT @message   -- Declare an inner cursor based   
       -- on au_id from the outer cursor.   DECLARE titles_cursor CURSOR FOR 
       SELECT t.title
       FROM titleauthor ta, titles t
       WHERE ta.title_id = t.title_id AND
       ta.au_id = @au_id   -- Variable value from the outer cursor   OPEN titles_cursor
       FETCH NEXT FROM titles_cursor INTO @title   IF @@FETCH_STATUS <> 0 
          PRINT '         <<No Books>>'        WHILE @@FETCH_STATUS = 0
       BEGIN
          
          SELECT @message = '         ' + @title
          PRINT @message
          FETCH NEXT FROM titles_cursor INTO @title
       
       END   CLOSE titles_cursor
       DEALLOCATE titles_cursor
       
       -- Get the next author.
       FETCH NEXT FROM authors_cursor 
       INTO @au_id, @au_fname, @au_lname
    ENDCLOSE authors_cursor
    DEALLOCATE authors_cursor
    GO