本帖最后由 zhangrongchao_ 于 2014-12-11 17:10:51 编辑

解决方案 »

  1.   

    把empno 换成一个不存在的试试,你会发现并不是指向第一条应为他不存在。
    但是能运行没有错误。
      

  2.   

    把empno 换成一个不存在数据后,运行显示无数据,然后这说明了什么么?
    还是指open 游标之后指针其实没有指向第一行数据?
      

  3.   

    open之后应该未指向任何数据,fetch是获取下一条数据,fetch之后才会对指针进行更新,同时读取当前行的数据
      

  4.   

    open的时候不会读数据,FETCH才读。
    1、说明游标。说明游标的时候并不执行select语句。
    declare <游标名> cursor for <select语句>;
    2、打开游标。打开游标实际上是执行相应的select语句,把查询结果读取到缓冲区中。这时候游标处于活动状态,指针指向查询结果集的第一条纪录。
     open <游标名>;
    3、推进游标指针并读取当前纪录。用fetch语句把游标指针向前推进一条纪录,同时将缓冲区中的当前纪录读取出来送到变量中。fetch语句通常用在一个循环结构体中,通过循环执行fetch语句逐条取出结果集中的行进行处理。现在好多数据库中,还允许任意方向任意步长易懂游标指针,而不仅仅是把游标指针向前推进一行了。
     fetch <游标名> into <变量1>,<变量2>...
    4、关闭游标。用close语句关闭游标,释放结果集占用的缓冲区及其他资源。游标关闭后,就不再和原来的查询结果集相联系。但游标可以再次打开,与新的查询结果相联系。
     close <游标名>;
      

  5.   

    我的意思是,按照我的查询条件应该只有一条记录,如果open之后指针指向结果集的第一条数据,那么在接下来fetch后就指向下一条(为空),但是为什么cur_emp%found为真呢?
      

  6.   

    cur_emp%found这个判断的是上次fetch是否取到数据,和当前指针没啥关系
      

  7.   

    把empno 换成一个不存在数据后,运行显示无数据,然后这说明了什么么?
    还是指open 游标之后指针其实没有指向第一行数据?
    是没有指向第一行呗。如果指向第一行,没有,是不是就会报错