java通过jdbc查询数据

前言:

工作中经常需要查询数据库中的数据,之前一直是通过第三方图形界面工具来操作的,最近在学习java数据库相关的内容,现通过java实现对数据库的查询操作。

说明:

该项目是通过maven来构建的,现主要记录下该项目的整体结构,以及对应的代码,如下:

  • 1.项目整体结构图
  • 2.pom.xml中引入依赖
  • 3.添加数据库和日志的配置文件
  • 4.编写操作数据库的核心代码(通过jdbc实现)
  • 5.测试结果
该代码特点:

查询出来的数据是以字段名组成键的键值对,可以直接转换为json数据,如:

  • 查询出来的数据格式:
      {total=2, data=[{full_name=null}, {full_name=北京百度有限公司}]}
  • 转换后的数据格式:
      {"total":2,"data":[{"full_name":null},{"full_name":"北京百度有限公司"}]}
项目整体结构图:
pom.xml中引入依赖:
<project xmlns="http://maven.apache.org/POM/4.0.0"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>

    <groupId>com.tools</groupId>
    <artifactId>operate_db</artifactId>
    <version>1.0-SNAPSHOT</version>
    <packaging>jar</packaging>
    <dependencies>
        <!-- 解析json -->
        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>fastjson</artifactId>
            <version>1.2.39</version>
        </dependency>
        <!-- 单元测试 -->
        <dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <version>RELEASE</version>
        </dependency>

        <!-- hive的jdbc -->
        <dependency>
            <groupId>org.apache.hive</groupId>
            <artifactId>hive-jdbc</artifactId>
            <version>1.2.1</version>
        </dependency>

        <!-- postgresql的jdbc -->
        <dependency>
            <groupId>postgresql</groupId>
            <artifactId>postgresql</artifactId>
            <version>9.1-901.jdbc4</version>
        </dependency>

        <!-- hadoop的组件 -->
        <dependency>
            <groupId>org.apache.hadoop</groupId>
            <artifactId>hadoop-common</artifactId>
            <version>2.4.1</version>
        </dependency>

        <!-- 日志相关 -->
        <dependency>
            <groupId>org.apache.logging.log4j</groupId>
            <artifactId>log4j-api</artifactId>
            <version>2.11.2</version>
        </dependency>
    </dependencies>

    <build>
        <resources>
            <!--表示把java目录下的有关xml文件,properties文件编译/打包的时候放在resource目录下-->
            <resource>
                <directory>${basedir}/src/main/java</directory>
                <includes>
                    <include>**/*.properties</include>
                    <include>**/*.xml</include>
                </includes>
            </resource>
            <resource>
                <directory>${basedir}/src/main/resources</directory>
            </resource>
        </resources>
    </build>
</project>
添加数据库和日志的配置文件:
  • 数据库配置文件-DB.properties
# ================  操作hive库  =================
# 驱动
#className=org.apache.hive.jdbc.HiveDriver
## 数据库url
#url=jdbc:hive2://127.0.0.1:10000/default
## 用户名
#username=username
## 密码
#password=password
# ================  操作pg库  =================
# 驱动
className=org.postgresql.Driver
# 数据库url
url=jdbc:postgresql://127.0.0.1:5432/dbname
# 用户名
username=username
# 密码
password=password
  • 日志配置文件-log4j.properties
# 日志输出等级
log4j.rootLogger=WARN, stdout
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern=%d %p [%c] - %m%n
编写操作数据库的核心代码(通过jdbc实现):
  • DBUtils.java
package com.tools.utils;

import java.io.*;
import java.sql.*;
import java.util.*;


public class DBUtils {
    private static String className;
    private static String url;
    private static String username;
    private static String password;

    static {
        //读取配置文件
        try {
            // 获取hive.properties文件的路径
            InputStream is = DBUtils.class.getClassLoader().getResourceAsStream("DB.properties");
            Properties prop = new Properties();
            prop.load(is);
            // 读取配置文件的值
            className = prop.getProperty("className");
            url = prop.getProperty("url");
            username = prop.getProperty("username");
            password = prop.getProperty("password");

        } catch (FileNotFoundException e) {
            e.printStackTrace();
        } catch (IOException e) {
            e.printStackTrace();
        }
        //加载驱动
        try {
            Class.forName(className);
        } catch (ClassNotFoundException e) {
            e.printStackTrace();
        }
    }

    public static Map<String, Object> query(String sql) {

        Connection conn = null;
        PreparedStatement pstsm = null;
        ResultSet rs = null;
        // 定义map
        Map<String, Object> resultMap = new HashMap<String, Object>();
        try {

            // 获取连接对象
            conn = DriverManager.getConnection(url, username, password);

            pstsm = conn.prepareStatement(sql);
            rs = pstsm.executeQuery();
            // 获取结果集的元数据信息
            ResultSetMetaData rsmd = rs.getMetaData();

            // 获取列字段的个数
            int colunmCount = rsmd.getColumnCount();

            // 存储列名的数组
            String[] columnNames = new String[colunmCount];

            for (int i = 0; i < colunmCount; i++) {
                // 获取所有的字段名称
                columnNames[i] = rsmd.getColumnLabel(i + 1);

            }
            // 将数据存储到数据中
            ArrayList<Object> list = new ArrayList<Object>();
            while (rs.next()) {
                Map<String, Object> perMap = new HashMap<String, Object>();
                for (int i = 0; i < colunmCount; i++) {
                    // 获取列名
                    String columnName = columnNames[i];
                    // 获取该列对应的值
                    Object value = rs.getObject(columnName);
                    perMap.put(columnName, value);
                }
                list.add(perMap);
            }

            // 计算数据的总数
            int total = list.size();
            resultMap.put("data", list);
            resultMap.put("total", total);

        } catch (Exception e) {
            e.printStackTrace();
        } finally {
            //
            close(conn, pstsm, rs);
        }

        return resultMap;
    }

    // 关闭数据库连接
    public static void close(Connection conn, PreparedStatement pstsm, ResultSet rs) {
        try {
            rs.close();
        } catch (SQLException e) {
            e.printStackTrace();
        }
        try {
            pstsm.close();
        } catch (SQLException e) {
            e.printStackTrace();
        }
        try {
            conn.close();
        } catch (SQLException e) {
            e.printStackTrace();
        }
    }

}

测试结果:
package com.tools.utils;

import com.alibaba.fastjson.JSON;
import com.alibaba.fastjson.serializer.SerializerFeature;
import org.junit.Test;

import java.util.Map;

public class TestHive {

    /**
     * 查询数据库数据
     */
    @Test
    public void query() {
        // sql语句
        String sql = "select * from custom";
        // 查询数据
        Map<String, Object> data = DBUtils.query(sql);
        System.out.println(data);
        // 转换为json字符串,WriteMapNullValue:表示保留为null的字段
        String result = JSON.toJSONString(data, SerializerFeature.WriteMapNullValue);
        System.out.println(result);// {"total":2,"data":[{"full_name":null},{"full_name":"北京百度有限公司"}]}
    }
}

喜欢关注点个赞!

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,163评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,301评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,089评论 0 352
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,093评论 1 292
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,110评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,079评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,005评论 3 417
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,840评论 0 273
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,278评论 1 310
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,497评论 2 332
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,667评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,394评论 5 343
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,980评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,628评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,796评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,649评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,548评论 2 352

推荐阅读更多精彩内容