java通過jdbc查詢數(shù)據(jù)

前言:

工作中經(jīng)常需要查詢數(shù)據(jù)庫中的數(shù)據(jù),之前一直是通過第三方圖形界面工具來操作的苛预,最近在學(xué)習(xí)java數(shù)據(jù)庫相關(guān)的內(nèi)容,現(xiàn)通過java實(shí)現(xiàn)對數(shù)據(jù)庫的查詢操作祥款。

說明:

該項(xiàng)目是通過maven來構(gòu)建的甜熔,現(xiàn)主要記錄下該項(xiàng)目的整體結(jié)構(gòu)只搁,以及對應(yīng)的代碼,如下:

  • 1.項(xiàng)目整體結(jié)構(gòu)圖
  • 2.pom.xml中引入依賴
  • 3.添加數(shù)據(jù)庫和日志的配置文件
  • 4.編寫操作數(shù)據(jù)庫的核心代碼(通過jdbc實(shí)現(xiàn))
  • 5.測試結(jié)果
該代碼特點(diǎn):

查詢出來的數(shù)據(jù)是以字段名組成鍵的鍵值對妖滔,可以直接轉(zhuǎn)換為json數(shù)據(jù)隧哮,如:

  • 查詢出來的數(shù)據(jù)格式:
    ??{total=2, data=[{full_name=null}, {full_name=北京百度有限公司}]}
  • 轉(zhuǎn)換后的數(shù)據(jù)格式:
    ??{"total":2,"data":[{"full_name":null},{"full_name":"北京百度有限公司"}]}
項(xiàng)目整體結(jié)構(gòu)圖:
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>

        <!-- 日志相關(guān) -->
        <dependency>
            <groupId>org.apache.logging.log4j</groupId>
            <artifactId>log4j-api</artifactId>
            <version>2.11.2</version>
        </dependency>
    </dependencies>

    <build>
        <resources>
            <!--表示把java目錄下的有關(guān)xml文件,properties文件編譯/打包的時(shí)候放在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>
添加數(shù)據(jù)庫和日志的配置文件:
  • 數(shù)據(jù)庫配置文件-DB.properties
# ================  操作hive庫  =================
# 驅(qū)動(dòng)
#className=org.apache.hive.jdbc.HiveDriver
## 數(shù)據(jù)庫url
#url=jdbc:hive2://127.0.0.1:10000/default
## 用戶名
#username=username
## 密碼
#password=password
# ================  操作pg庫  =================
# 驅(qū)動(dòng)
className=org.postgresql.Driver
# 數(shù)據(jù)庫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
編寫操作數(shù)據(jù)庫的核心代碼(通過jdbc實(shí)現(xiàn)):
  • 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();
        }
        //加載驅(qū)動(dòng)
        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();
            // 獲取結(jié)果集的元數(shù)據(jù)信息
            ResultSetMetaData rsmd = rs.getMetaData();

            // 獲取列字段的個(gè)數(shù)
            int colunmCount = rsmd.getColumnCount();

            // 存儲列名的數(shù)組
            String[] columnNames = new String[colunmCount];

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

            }
            // 將數(shù)據(jù)存儲到數(shù)據(jù)中
            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];
                    // 獲取該列對應(yīng)的值
                    Object value = rs.getObject(columnName);
                    perMap.put(columnName, value);
                }
                list.add(perMap);
            }

            // 計(jì)算數(shù)據(jù)的總數(shù)
            int total = list.size();
            resultMap.put("data", list);
            resultMap.put("total", total);

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

        return resultMap;
    }

    // 關(guān)閉數(shù)據(jù)庫連接
    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();
        }
    }

}

測試結(jié)果:
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 {

    /**
     * 查詢數(shù)據(jù)庫數(shù)據(jù)
     */
    @Test
    public void query() {
        // sql語句
        String sql = "select * from custom";
        // 查詢數(shù)據(jù)
        Map<String, Object> data = DBUtils.query(sql);
        System.out.println(data);
        // 轉(zhuǎn)換為json字符串,WriteMapNullValue:表示保留為null的字段
        String result = JSON.toJSONString(data, SerializerFeature.WriteMapNullValue);
        System.out.println(result);// {"total":2,"data":[{"full_name":null},{"full_name":"北京百度有限公司"}]}
    }
}

喜歡關(guān)注點(diǎn)個(gè)贊!

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末座舍,一起剝皮案震驚了整個(gè)濱河市沮翔,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌曲秉,老刑警劉巖采蚀,帶你破解...
    沈念sama閱讀 206,126評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異承二,居然都是意外死亡榆鼠,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,254評論 2 382
  • 文/潘曉璐 我一進(jìn)店門矢洲,熙熙樓的掌柜王于貴愁眉苦臉地迎上來璧眠,“玉大人,你說我怎么就攤上這事≡鹁玻” “怎么了袁滥?”我有些...
    開封第一講書人閱讀 152,445評論 0 341
  • 文/不壞的土叔 我叫張陵,是天一觀的道長灾螃。 經(jīng)常有香客問我题翻,道長,這世上最難降的妖魔是什么腰鬼? 我笑而不...
    開封第一講書人閱讀 55,185評論 1 278
  • 正文 為了忘掉前任嵌赠,我火速辦了婚禮,結(jié)果婚禮上熄赡,老公的妹妹穿的比我還像新娘姜挺。我一直安慰自己,他們只是感情好彼硫,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,178評論 5 371
  • 文/花漫 我一把揭開白布炊豪。 她就那樣靜靜地躺著,像睡著了一般拧篮。 火紅的嫁衣襯著肌膚如雪词渤。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 48,970評論 1 284
  • 那天串绩,我揣著相機(jī)與錄音缺虐,去河邊找鬼。 笑死礁凡,一個(gè)胖子當(dāng)著我的面吹牛高氮,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播把篓,決...
    沈念sama閱讀 38,276評論 3 399
  • 文/蒼蘭香墨 我猛地睜開眼纫溃,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了韧掩?” 一聲冷哼從身側(cè)響起紊浩,我...
    開封第一講書人閱讀 36,927評論 0 259
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎疗锐,沒想到半個(gè)月后坊谁,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 43,400評論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡滑臊,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,883評論 2 323
  • 正文 我和宋清朗相戀三年口芍,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片雇卷。...
    茶點(diǎn)故事閱讀 37,997評論 1 333
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡鬓椭,死狀恐怖颠猴,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情小染,我是刑警寧澤翘瓮,帶...
    沈念sama閱讀 33,646評論 4 322
  • 正文 年R本政府宣布,位于F島的核電站裤翩,受9級特大地震影響资盅,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜踊赠,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,213評論 3 307
  • 文/蒙蒙 一呵扛、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧筐带,春花似錦今穿、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,204評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽凤价。三九已至鸽斟,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間利诺,已是汗流浹背富蓄。 一陣腳步聲響...
    開封第一講書人閱讀 31,423評論 1 260
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留慢逾,地道東北人立倍。 一個(gè)月前我還...
    沈念sama閱讀 45,423評論 2 352
  • 正文 我出身青樓,卻偏偏與公主長得像侣滩,于是被迫代替她去往敵國和親口注。 傳聞我的和親對象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,722評論 2 345

推薦閱讀更多精彩內(nèi)容