Java连接HANA数据库

package hs.hsapp.util;

import java.sql.*;

import java.util.ArrayList;

import java.util.HashMap;

import java.util.List;

import java.util.Map;

public class HanaJdbc {

private static final String DRIVER = "com.sap.db.jdbc.Driver"; //jdbc 4.0

private static final String URL = "jdbc:sap://IP:30041?reconnect=true";

复制代码
public List<Map<Object, Object>> select(String sql) {
    List<Map<Object, Object>> list = new ArrayList<>();
    try{
        Connection con = this.getConnection(DRIVER, URL, "USR", "PWD");
        PreparedStatement pstmt = con.prepareStatement(sql);
        ResultSet rs = pstmt.executeQuery();
        //this.processResult(rs);
        ResultSetMetaData rsmd = rs.getMetaData();
        int colNum = rsmd.getColumnCount();
        while (rs.next()) {
            Map<Object,Object> map = new HashMap<>();
            for(int i = 1; i <= colNum; i++) {
                //System.out.println("col: " + rsmd.getColumnName(i) + ",val: " + rs.getObject(i));
                map.put(rsmd.getColumnName(i),rs.getObject(i));
            }
            list.add(map);
        }
        this.closeConnection(con, pstmt);
    }catch (Exception ex) {
        ex.printStackTrace();
    }
    return list;
}

private void processResult(ResultSet rs) throws Exception {
    if (rs.next()) {
        ResultSetMetaData rsmd = rs.getMetaData();
        int colNum = rsmd.getColumnCount();
        for (int i = 1; i <= colNum; i++) {
            if (i == 1) {
                System.out.print(rsmd.getColumnName(i));
            } else {
                System.out.print("\t" + rsmd.getColumnName(i));
            }

        }
        System.out.print("\n");
        System.out.println("-----------------------");
        do {
            for (int i = 1; i <= colNum; i++) {
                if (i == 1) {
                    System.out.print(rs.getString(i));
                } else {
                    System.out.print("\t"
                            + (rs.getString(i) == null ? "null" : rs
                            .getString(i).trim()));
                }

            }
            System.out.print("\n");
        } while (rs.next());
    } else {
        System.out.println("query not result.");
    }

}

private Connection getConnection(String driver, String url, String user,
                                 String password) throws Exception {
    Class.forName(driver);
    return DriverManager.getConnection(url, user, password);

}

private void closeConnection(Connection con, Statement stmt)
        throws Exception {
    if (stmt != null) {
        stmt.close();
    }
    if (con != null) {
        con.close();
    }
}

}

相关推荐
先吃饱再说2 小时前
存储的进化:从 MySQL 到浏览器缓存,数据到底住在哪?
数据库
Nturmoils2 小时前
字段太多看不全,ksql 的展开模式和输出控制怎么用
数据库·后端
Databend4 小时前
Agent 轨迹分析与归因的数据工程实践
大数据·数据库·agent
这个DBA有点耶4 小时前
SQL改写进阶:标量子查询的“隐形代价”与消除实战
数据库·mysql·架构
smallyoung6 小时前
数据库乐观锁深度解析:MySQL、PostgreSQL 实战 + Spring Boot 集成指南
数据库·mysql·postgresql
parade岁月6 小时前
MySQL JOIN解析:朴实无华但食之有味
数据库·后端
用户3169353811836 小时前
MySQL服务无法启动问题解决全记录
数据库
SamDeepThinking9 小时前
裁掉那个差程序员后,给你看团队里高手的代码:这个习惯,希望你有
java·后端·程序员
朕瞧着你甚好9 小时前
技术雷达 & Java 集成评估报告 — Apache Tika 3.3.1
java·ai编程
vivo互联网技术10 小时前
从 10 分钟到 1 秒:ES 深度分页任意跳页的三轮优化实战
服务器·数据库·redis·elasticsearch·深度分页