zoukankan      html  css  js  c++  java
  • 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
    View Code

    不过测试的过程学到了很多东西。 比如 pargs pid可以查看一个java进程的参数。

    比如设置classpath等。 这些明天再写。 

  • 相关阅读:
    微软系统及开发工具官方下载地址
    Office2010文档的MIME类型
    Android开发中Activity的生命周期
    DWZ框架POST方式提交Form提示JSON文件下载
    JAVA开发环境搭建
    FastJSON解析.Net生成的JSON字符串
    SQL Server 2008 如何更改服务器身份验证模式
    如何快速解决IIS中发布的网站不能访问。
    QlickView
    Lamabda表达式
  • 原文地址:https://www.cnblogs.com/kramer/p/3712258.html
Copyright © 2011-2022 走看看