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(); } } } } }
#Java自帶的日誌。
常見用法如下,列印日誌資訊:
logger.error("資料庫連線失敗",e)
logger.info("tableName:{},comment: {}",tableName,comment),{}是佔位符
LoggerFactory.getLogger(xxx.class)
指定類別初始化日誌對象,在日誌輸出的時候,可以列印出日誌資訊所在類別。
Connection 物件用於開啟與資料來源的連線。
Class.forName(driverName)
載入驅動程式。
DriverManager.getConnection(url,user,password)
取得資料庫連線。
PreparedStatement
用來執行SQL查詢語句的 API 之一。
結果集 (ResultSet) 是資料中查詢結果傳回的一種對象,結果集是儲存查詢結果的物件。
ps = conn.prepareStatement(SQL_SHOW_TABLE_STATUS)
執行前會對SQL語句進行預編譯的操作,然後就開始執行SQL語句,並傳回結果。
tableResult = ps.executeQuery()
把資料庫回應的查詢結果存放在ResultSet類別物件中供我們使用。
ResultSet中指標的初始位置位於第一行之前;第一次呼叫next()方法會將第一行設定為目前行。
分別代表執行資料庫show table status語句後查詢出的表名和表註解。配合ResultSet的getString()方法得到對應值。
以上是Java程式碼如何讀取資料庫表?的詳細內容。更多資訊請關注PHP中文網其他相關文章!