zoukankan      html  css  js  c++  java
  • java使用url和tns两种方式连接数据库执行存储过程

    1.url方式(连接数据库并执行一个查询):

    public static void main(String[] args) throws ClassNotFoundException, SQLException {
    Statement statement;
    ResultSet rs;
    Connection conn;
    String sql;
    /**
    db.driveName=oracle.jdbc.driver.OracleDriver
    db.username=user
    db.pwd=pwd
    db.url=jdbc:oracle:thin:@****:1521:ywxx
    */
    String userName = PropertiesUtil.getString("db.username");
    String userPwd = PropertiesUtil.getString("db.pwd");
    Class.forName(PropertiesUtil.getString("db.driveName"));
    String dbURL = PropertiesUtil.getString("db.url");
    conn = DriverManager.getConnection(dbURL, userName, userPwd);
    statement = conn.createStatement();
    sql = "select AA from task;";
    String aa;
    rs = statement.executeQuery(sql);
    while (rs.next()) {
    aa = rs.getString("AA");
    System.out.println(aa);
    }
    rs.close();
    conn.close();
    }

    2.tns需要根据名称去查找对应的信息,所以要配置一个查找路径(连接数据库并执行一个存储过程):

    public static void main(String[] args) throws ClassNotFoundException, SQLException, IllegalAccessException, InstantiationException {
            /**
             db.driveName=oracle.jdbc.driver.OracleDriver
             db.username=user
             db.pwd=pwd
             db.tns=orcl
             */
            String userName = PropertiesUtil.getString("db.username");
            String userPwd = PropertiesUtil.getString("db.pwd");
            String dbURL = "jdbc:oracle:thin:@" + PropertiesUtil.getString("db.tns");
            Class.forName(PropertiesUtil.getString("db.driveName"));
            Connection conn;
            CallableStatement callableStatement;
            System.setProperty("oracle.net.tns_admin", System.getenv("ORACLE_HOME") + File.separator + "NETWORK" + File.separator + "ADMIN");
            System.out.println(System.getProperty("oracle.net.tns_admin"));
            Class.forName("oracle.jdbc.driver.OracleDriver");
            conn = DriverManager.getConnection(dbURL, userName, userPwd);
            callableStatement = conn.prepareCall("{call pro_name}");
            callableStatement.execute();
            callableStatement.close();
            conn.close();
        }
  • 相关阅读:
    【概念】构造函数和析构函数
    【概念】使用Fixed创建固定大小的缓冲区
    Sqoop
    Flume组件
    Hive节点及原理
    Yarn
    Hive数据倾斜
    单例
    工厂设计模式
    JVM对象创建
  • 原文地址:https://www.cnblogs.com/garfieldcgf/p/6149969.html
Copyright © 2011-2022 走看看