首页 > 代码库 > v$open_cursor中的相同record
v$open_cursor中的相同record
之前在查看v$open_cursor的时候,发现很多相同的record。 让我很疑惑, sid saddr sql_id 都相同,我就想 这不是一个cursor吗? 那为什么在open_cursor中出现多次? 后来通过别人点拨明白了,这应该是一个相同的SQL语句被 session 打开了并运行了很多次。 当然,这里指的是java环境。 如果你在sqlplus 中运行同一个语句很多次 oracle是不会打开 多个同样的cursor的。 但是java jdbc编程的时候就不一样了。 java 的情形大致如下:
ResultSet rs1=stmt.executeQuery(sql); while(rs1.next()) System.out.print(rs1.getString("object_name")+" "); ResultSet rs1=stmt.executeQuery(sql); while(rs1.next()) System.out.print(rs1.getString("object_name")+" "); ResultSet rs1=stmt.executeQuery(sql); while(rs1.next()) System.out.print(rs1.getString("object_name")+" "); while(rs1.next()) System.out.print(rs1.getString("object_name")+" ");
这里把一个语句打开了4遍并且没有关闭,这样在oracle里面就会出现4行相同的条目。
00000003C38D3A98 219 PNADMIN 00000003B8786140 1708196829 6rpx3u1kx20yx select object_name from all_objects where rownum<2 00000003C38D3A98 219 PNADMIN 00000003B8786140 1708196829 6rpx3u1kx20yx select object_name from all_objects where rownum<2 00000003C38D3A98 219 PNADMIN 00000003B8786140 1708196829 6rpx3u1kx20yx select object_name from all_objects where rownum<2 00000003C38D3A98 219 PNADMIN 00000003B8786140 1708196829 6rpx3u1kx20yx select object_name from all_objects where rownum<2
不过测试的过程学到了很多东西。 比如 pargs pid可以查看一个java进程的参数。
比如设置classpath等。 这些明天再写。
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。