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 

  • 相关阅读:
    网页请求过滤器Filter
    高级查询
    SQL编程
    数据库的实现
    数据库设计
    使用ADO.NET查询和操作数据
    使用ADO.NET访问数据库
    深入C#中的String类
    使用属性升级MyBank
    C#语法快速热身
  • 原文地址:https://www.cnblogs.com/FlyAway2013/p/3822419.html
Copyright © 2011-2022 走看看