首頁 >Java >java教程 >Java程式碼如何讀取資料庫表?

Java程式碼如何讀取資料庫表?

WBOY
WBOY轉載
2023-05-08 09:55:071351瀏覽

Java讀取資料庫表格

package com.easycrud.builder;
import com.easycrud.utils.PropertiesUtils;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import java.sql.*;
/**
 * @BelongsProject: EasyCrud
 * @BelongsPackage: com.easycrud.builder
 * @Author: xpx
 * @Email: 2436846019@qq.com
 * @CreateTime: 2023-05-02  18:02
 * @Description: 读Table
 * @Version: 1.0
 */
public class BuildTable {
    private static final Logger logger = LoggerFactory.getLogger(BuildTable.class);
    private static Connection conn = null;
    /**
     * 查表名和表注释
     */
    private static String SQL_SHOW_TABLE_STATUS = "show table status";
    /**
     * 读配置,连接数据库
     */
    static {
        String driverName = PropertiesUtils.getString("db.driver.name");
        String url = PropertiesUtils.getString("db.url");
        String user = PropertiesUtils.getString("db.username");
        String password = PropertiesUtils.getString("db.password");
        try {
            Class.forName(driverName);
            conn = DriverManager.getConnection(url,user,password);
        } catch (Exception e) {
            logger.error("数据库连接失败",e);
        }
    }
    /**
     * 读取表
     */
    public static void getTables() {
        PreparedStatement ps = null;
        ResultSet tableResult = null;
        try{
            ps = conn.prepareStatement(SQL_SHOW_TABLE_STATUS);
            tableResult = ps.executeQuery();
            while(tableResult.next()) {
                String tableName = tableResult.getString("name");
                String comment = tableResult.getString("comment");
                logger.info("tableName:{},comment:{}",tableName,comment);
            }
        }catch (Exception e){
            logger.error("读取表失败",e);
        }finally {
            if (tableResult != null) {
                try {
                    tableResult.close();
                } catch (SQLException e) {
                    e.printStackTrace();
                }
            }
            if (ps != null) {
                try {
                    ps.close();
                } catch (SQLException e) {
                    e.printStackTrace();
                }
            }
            if (conn != null) {
                try {
                    conn.close();
                } catch (SQLException e) {
                    e.printStackTrace();
                }
            }
        }
    }
}

新手引導

Logger

#Java自帶的日誌。

常見用法如下,列印日誌資訊:

logger.error("資料庫連線失敗",e)

logger.info("tableName:{},comment: {}",tableName,comment),{}是佔位符

LoggerFactory.getLogger(xxx.class)

指定類別初始化日誌對象,在日誌輸出的時候,可以列印出日誌資訊所在類別。

Connection

Connection 物件用於開啟與資料來源的連線。

Class.forName(driverName)

載入驅動程式。

DriverManager.getConnection(url,user,password)

取得資料庫連線。

PreparedStatement

用來執行SQL查詢語句的 API 之一。

ResultSet

結果集 (ResultSet) 是資料中查詢結果傳回的一種對象,結果集是儲存查詢結果的物件。

ps = conn.prepareStatement(SQL_SHOW_TABLE_STATUS)

執行前會對SQL語句進行預編譯的操作,然後就開始執行SQL語句,並傳回結果。

tableResult = ps.executeQuery()

把資料庫回應的查詢結果存放在ResultSet類別物件中供我們使用。

ResultSet中next()方法

ResultSet中指標的初始位置位於第一行之前;第一次呼叫next()方法會將第一行設定為目前行。

name和comment

分別代表執行資料庫show table status語句後查詢出的表名和表註解。配合ResultSet的getString()方法得到對應值。

以上是Java程式碼如何讀取資料庫表?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文轉載於:yisu.com。如有侵權,請聯絡admin@php.cn刪除