zoukankan      html  css  js  c++  java
  • 数据库的Timeout

     数据库的Timeout 其实有很多种情况。

    一个是执行的超时时间 executionTimeOut,一个是连接的超时时间connectionTimeOut,

    还有呢? 等待的超时时间 ReadTimeout。不过很多数据库情况下connectionTimeOut 就是ReadTimeout

    props.put("user", userName);
    props.put("password", passSecret);
    if ("oracle".equals(dbType)) {
    //props.put("connectionProperties", "oracle.net.CONNECT_TIMEOUT=10000;oracle.jdbc.ReadTimeout=10000");
    props.put("oracle.net.CONNECT_TIMEOUT", "10000");
    props.put("oracle.jdbc.ReadTimeout", "10000");
    }

    String sleepsql = "declare "+
    "begin "+
    "sys.dbms_lock.sleep(20); "+
    "dbms_output.put_line('asfasf');"+
    "end;";
    String sqlStr =
    "select distinct tablespace_name from sys.dba_tables where owner = '"
    + dbInfo.getName().toUpperCase()
    + "' and trim(tablespace_name) is not null";
    List<String> dbList = new ArrayList<String>();
    PreparedStatement statement = null;
    ResultSet rs = null;
    try {
    CallableStatement callableStatement = conn.prepareCall(sleepsql);
    callableStatement.execute();
    //conn.setNetworkTimeout(Executors.newCachedThreadPool(), 30000);
    } catch (SQLException e) {
    e.printStackTrace();
    } finally {

    }

    开始是通过下面的,不过一直就是报错,行不通, 貌似驱动版本不够新。

    conn.setNetworkTimeout(Executors.newCachedThreadPool(), 30000);

    有关数据库的锁:

    http://www.cnblogs.com/cqubityj/archive/2012/06/16/2551947.html

    http://www.cnblogs.com/leemoby/p/3583428.html


    LOCK TABLE iempeam.t_aa IN EXCLUSIVE MODE

    SELECT * FROM  iempeam.t_aa  TABLOCKX 

  • 相关阅读:
    机器学习1
    第15次作业
    算符优先分析
    自下而上语法分析
    实验二 递归下降语法分析
    LL(1)文法的判断,递归下降分析程序
    消除左递归
    【shell】通过shell编写ping包及arp的监控并发送短信
    os和sys模块
    time模块和random模块
  • 原文地址:https://www.cnblogs.com/FlyAway2013/p/3822419.html
Copyright © 2011-2022 走看看