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("Database Connection failed",e)
logger.info("tableName:{},comment:{}",tableName,comment), { } is 자리표시자
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() 메서드를 처음 호출하면 첫 번째 행이 현재 행으로 설정됩니다.
는 각각 데이터베이스 표시 테이블 상태 문을 실행한 후 쿼리된 테이블 이름과 테이블 설명을 나타냅니다. 해당 값을 얻으려면 ResultSet의 getString() 메소드를 사용하십시오.
위 내용은 Java 코드는 데이터베이스 테이블을 어떻게 읽나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!