Java讀取數(shù)據(jù)庫表的示例代碼
Java讀取數(shù)據(jù)庫表
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"; /** * 讀配置,連接數(shù)據(jù)庫 */ 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("數(shù)據(jù)庫連接失敗",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(); } } } } }
新手引導(dǎo)
Logger
Java自帶的日志。
常見用法如下,打印日志信息:
logger.error("數(shù)據(jù)庫連接失敗",e)
logger.info("tableName:{},comment:{}",tableName,comment),{}是占位符
LoggerFactory.getLogger(xxx.class)
指定類初始化日志對象,在日志輸出的時候,可以打印出日志信息所在類。
Connection
Connection 對象用于打開與數(shù)據(jù)源的連接。
Class.forName(driverName)
加載驅(qū)動程序。
DriverManager.getConnection(url,user,password)
獲取數(shù)據(jù)庫連接。
PreparedStatement
用來執(zhí)行SQL查詢語句的 API 之一。
ResultSet
結(jié)果集 (ResultSet) 是數(shù)據(jù)中查詢結(jié)果返回的一種對象,結(jié)果集是一個存儲查詢結(jié)果的對象。
ps = conn.prepareStatement(SQL_SHOW_TABLE_STATUS)
執(zhí)行前會對SQL語句進(jìn)行預(yù)編譯的操作,然后就開始執(zhí)行SQL語句,并返回結(jié)果。
tableResult = ps.executeQuery()
把數(shù)據(jù)庫響應(yīng)的查詢結(jié)果存放在ResultSet類對象中供我們使用。
ResultSet中next()方法
ResultSet中指針的初始位置位于第一行之前;第一次調(diào)用next()方法將會把第一行設(shè)置為當(dāng)前行。
name和comment
分別代表執(zhí)行數(shù)據(jù)庫show table status語句后查詢出的表名和表注釋。配合ResultSet的getString()方法得到對應(yīng)值。
到此這篇關(guān)于Java讀取數(shù)據(jù)庫表 的文章就介紹到這了,更多相關(guān)Java讀取數(shù)據(jù)庫表 內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Spring實戰(zhàn)之Qualifier注解用法示例
這篇文章主要介紹了Spring實戰(zhàn)之Qualifier注解用法,結(jié)合實例形式詳細(xì)分析了spring Qualifier注解相關(guān)配置、定義與使用方法,需要的朋友可以參考下2019-12-12javaWeb連接數(shù)據(jù)庫實現(xiàn)簡單登陸注冊功能的全過程
初學(xué)javaWeb,老師留下一小作業(yè),用JAVA實現(xiàn)與服務(wù)器端交互,實現(xiàn)登錄和注冊功能,下面這篇文章主要給大家介紹了關(guān)于javaWeb連接數(shù)據(jù)庫實現(xiàn)簡單登陸注冊功能的相關(guān)資料,需要的朋友可以參考下2022-06-06解析SpringBoot?搭建基于?MinIO?的高性能存儲服務(wù)的問題
Minio是Apache?License?v2.0下發(fā)布的對象存儲服務(wù)器,使用MinIO構(gòu)建用于機器學(xué)習(xí),分析和應(yīng)用程序數(shù)據(jù)工作負(fù)載的高性能基礎(chǔ)架構(gòu)。這篇文章主要介紹了SpringBoot?搭建基于?MinIO?的高性能存儲服務(wù),需要的朋友可以參考下2022-03-03POI讀取excel簡介_動力節(jié)點Java學(xué)院整理
這篇文章主要介紹了POI讀取excel簡介,詳細(xì)的介紹了什么是Apache POI和組件,有興趣的可以了解了解一下2017-08-08Tomcat數(shù)據(jù)源配置方法_JBuilder中
今天幫一同事配置一個數(shù)據(jù)源,采用tomcat5.5.9,本來是個很簡單的事,以前也配過,但由于很長時間沒用過容器提供的數(shù)據(jù)源了(IOC用慣了),也只記的個大概了,所以剛開始一配就出錯了,google了一下,有很多資料,照著試試卻都不好使(到不是別人說的不對,只是大家用的版本不同)。2008-10-10