>Java >java지도 시간 >Java 코드는 데이터베이스 테이블을 어떻게 읽나요?

Java 코드는 데이터베이스 테이블을 어떻게 읽나요?

WBOY
WBOY앞으로
2023-05-08 09:55:071362검색

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("Database Connection failed",e)

logger.info("tableName:{},comment:{}",tableName,comment), { } is 자리표시자

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

는 각각 데이터베이스 표시 테이블 상태 문을 실행한 후 쿼리된 테이블 이름과 테이블 설명을 나타냅니다. 해당 값을 얻으려면 ResultSet의 getString() 메소드를 사용하십시오.

위 내용은 Java 코드는 데이터베이스 테이블을 어떻게 읽나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 yisu.com에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제