zoukankan      html  css  js  c++  java
  • Oracle Jdbc demo

    两种方式:

    thin是一种瘦客户端的连接方式,即采用这种连接方式不需要安装oracle客户端,只要求classpath中包含jdbc驱动的jar包就行。thin就是纯粹用Java写的ORACLE数据库访问接口。
    oci 是一种胖客户端的连接方式,即采用这种连接方式需要安装oracle客户端。oci是Oracle Call Interface的首字母缩写,是ORACLE公司提供了访问接口,就是使用Java来调用本机的Oracle客户端,然后再访问数据库,优点是速度 快,但是需要安装和配置数据库。

    从使用thin驱动切换到oci驱动在配置来说很简单,只需把连接字符串java:oracle:thin:@hostip:port:实例名换为java:oracle:oci@本地服务名即可。

    如:从 jdbc:oracle:thin:@10.1.1.2:1521:xe
    改成
    jdbc:oracle:oci8:@xe

     调用storedprocedure使用方式:

    CallableStatement cstmt =   con.prepareCall("CALL  spname(? , ?)") ; 

      获取数据库的元数据信息:

    DatabaseMetaData dbmd = con.getMetaData();
    获取结果集的元数据信息:
    ResultSetMetaData rsmd = rs.getMetaData();

    statement构造函数可以包含3个参数:

    • resultSetType,它的取值包括:ResultSet.TYPE_FORWARD_ONLYResultSet.TYPE_SCROLL_INSENSITIVEResultSet.TYPE_SCROLL_SENSITIVE,默认情况下,该参数的值是ResultSet.TYPE_FORWARD_ONLY
    • resultSetConcurrency,它的取值包括:ResultSet.CONCUR_READ_ONLYResultSet.CONCUR_UPDATABLE,默认情况下,该参数的值是ResultSet.CONCUR_READ_ONLY
    • resultSetHoldability,它的取值包括:ResultSet.HOLD_CURSORS_OVER_COMMITResultSet.CLOSE_CURSORS_AT_COMMIT

    获取数据集的时候,可以设定resultSet.SetFetchSize来避免outofmemory错误的发生。

    关于jdbc数据库连接,同一个数据库连接,不能同时做多件事情,必须串行做?还是这是由数据库的隔离级别决定的?

    import java.sql.Connection;
    import java.sql.DriverManager;
    import java.sql.PreparedStatement;
    import java.sql.ResultSet;
    import java.sql.ResultSetMetaData;
    import java.sql.SQLException;
    
    
    public class jdbcdemo {
    
        //create table mytest(key varchar2(2000),value varchar2(2000));
        
        public static final String ORACLE_DRIVER_CLASS = "oracle.jdbc.driver.OracleDriver";
        
        public    static void main(String[] args)
        {
            System.out.println("hello jdbc");
             
                final Connection conn = getConn(false);
                //selectDemo("select * from mytest");
                //insertDemo(conn,10000,1000);
                //selectDemo("select * from mytest");
                /*
                new Thread(){public void run()
                    {
                        try {
                            insertDemo(conn,100,10);
                        } catch (SQLException e) {
                            e.printStackTrace();
                        }
                    }}.start();
                    
                new Thread(){public void run()
                    {
                        try {
                            insertDemo(conn,100,10);
                        } catch (SQLException e) {
                            e.printStackTrace();
                        }
                    }}.start();
                    */
                new Thread(){public void run()
                {
                    try {
                        selectDemo(conn,"select * from mytest");
                    } catch (SQLException e) {
                        e.printStackTrace();
                    }
                }}.start();
                    try {
                        Thread.sleep(1000);
                        conn.commit();
                    } catch (Exception e) { 
                        e.printStackTrace();
                    }
             
        }
        
        static Connection getConn(boolean autoCommit)
        {
            Connection conn =    null;
            try {
                    Class.forName(ORACLE_DRIVER_CLASS);
                    //two method , use thin(pure java not need oracle client installed)
                    //or oci(need oracle client installed)                conn = DriverManager.getConnection("jdbc:oracle:thin:@192.168.99.105:1521:xe","system","student");
                    conn.setAutoCommit(autoCommit);
            } catch (ClassNotFoundException e) {
                e.printStackTrace();
            }
            catch(SQLException sqle)
            {
                sqle.printStackTrace();
            }
            return conn;
        }
        
        static void selectDemo(Connection conn,String sql) throws SQLException
        {
            PreparedStatement stmt = conn.prepareStatement(sql);
            ResultSet rs =  stmt.executeQuery();
            rs.setFetchSize(1);//it is useful to set this value when the resultset is very large
            ResultSetMetaData rsmd = rs.getMetaData();
            for(int index=1;index<=rsmd.getColumnCount();index++)
                System.out.print(rsmd.getColumnName(index)+"	");
            System.out.println();
            while(rs.next())
                {
                    for(int index=1;index<=rsmd.getColumnCount();index++)
                        System.out.print(rs.getString(index)+"	");
                    System.out.println();
                } 
        }
        
        static void insertDemo(Connection conn,int rowcount,int batchcount) throws SQLException
        {
            String sql="insert into mytest(key,value) values(?,?)";
            PreparedStatement stmt = conn.prepareStatement(sql);
            
            for(int i=1;i<=rowcount;i++)
            {
                stmt.setString(1,"Key"+i);
                stmt.setString(2,"Value"+i+" "+Thread.currentThread().getName());
                stmt.addBatch();
                if(i % batchcount == 0)
                    stmt.executeBatch();
            }
            stmt.executeBatch();
        }
     
    }
    Looking for a job working at Home about MSBI
  • 相关阅读:
    《Fluent Python》 CH.06_函数_使用一等函数实现设计模式 (函数式策略模式+命令模式)
    《Python+Spark 2.0+Hadoop》第10章 Python Spark RDD 读书笔记 (转换/动作运算、广播变量、累加器、示例略)
    《Fluent Python》 CH.05_数据结构-一等函数 (函数对象的各种内置函数、operator模块、itemgetter 和 attrgetter迭代/取值函数)
    JAVA时间字符串去空格、冒号和横杠
    Maven 构建生命周期(compile与install的区别)
    MySQL-进程占用CPU资源高问题分析
    K8S-二进制安装部署高可用集群环境
    Oracle-DG环境中Gap
    MySQL-主从复制环境升级小版本软件
    SequoiaDB
  • 原文地址:https://www.cnblogs.com/huaxiaoyao/p/4299122.html
Copyright © 2011-2022 走看看