Java 通过jdbc连接并使用postgre获取数据

第一次使用postgre数据库,有一些踩坑的地方,记录下,以下按照顺序操作

1.下载postgre驱动

注意不同的java版本对应不同的postgre驱动
在这里插入图片描述

2.pom.xml配置驱动

我这里使用的是idea,maven项目
所以在最外层pom和实际应用的业务包pom中配置即可

<dependency>
	<groupId>org.postgresql</groupId>
	<artifactId>postgresql</artifactId>
	<version>42.5.0</version>
</dependency>

3.代码实现

jdbc连接

public static void main(String[] args) {
       
        try {

            String url = "jdbc:postgresql://{ip}:{port}/{dbName}";
            Class.forName("org.postgresql.Driver");
            Connection connection= DriverManager.getConnection(url, "userName", "password");
            String sql ="select * from tableName";
            Statement statement = connection.createStatement();
            ResultSet resultSet = statement.executeQuery(sql);
            List list = convertList(resultSet);
            resultSet.close();
            statement.close();
            connection.close();
        } catch (Exception e) {
            e.printStackTrace();
        }
    }

具体获取的数据逻辑,我这里获取了每行每列数据

private static List<Map<String, ?>> convertList(ResultSet rs) throws SQLException{

        List<Map<String, ?>>  list = new ArrayList<>();
        ResultSetMetaData md = rs.getMetaData();//获取键名
        int columnCount = md.getColumnCount();//获取行的数量
        while (rs.next()) {
            Map<String, Object> orderedRecords = new LinkedHashMap<>();

            for (int i = 1; i <= columnCount; i++) {
                System.out.println(md.getColumnName(i) + "---" + rs.getObject(i));
                orderedRecords.put(md.getColumnName(i), rs instanceof BigInteger ? ((BigInteger) rs).longValue() : rs);
            }
            list.add(orderedRecords);
        }
        return list;
    }

表中数据
在这里插入图片描述
输出
!](https://img-blog.csdnimg.cn/dda8ad073a1d48a4997210f65c6a5f35.png)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

鲲志说

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值