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

