获取数据库表的 MetaData:

java
 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
import org.springframework.jdbc.core.ConnectionCallback;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.stereotype.Service;

import java.sql.DatabaseMetaData;
import java.sql.ResultSet;
import java.sql.ResultSetMetaData;
import java.sql.SQLException;
import java.util.*;


@Service
public class DynamicMetadataService {
    
    private final JdbcTemplate jdbcTemplate;
    
    public DynamicMetadataService(JdbcTemplate jdbcTemplate) {
        this.jdbcTemplate = jdbcTemplate;
    }

    /**
     * 获取表的元数据信息
     * 
     * @param tableName 数据库表名
     * @return 表的元数据信息
     */
    public List<Map<String, Object>> getTableMetadata(String tableName) {
        return jdbcTemplate.execute((ConnectionCallback<List<Map<String, Object>>>) conn -> {
            DatabaseMetaData metaData = conn.getMetaData();
            try (ResultSet columns = metaData.getColumns(
                    conn.getCatalog(),
                    conn.getSchema(),
                    tableName,
                    "%"
            )) {
                return extractColumnMetadata(columns);
            }
        });
    }
    
    private List<Map<String, Object>> extractColumnMetadata(ResultSet columns) throws SQLException {
        List<Map<String, Object>> metadataList = new ArrayList<>();
        ResultSetMetaData rsMeta = columns.getMetaData();
        int columnCount = rsMeta.getColumnCount();
        
        Map<String, String> columnNameMap = new HashMap<>();
        for (int i = 0; i < columnCount; i++) {
            columnNameMap.put(rsMeta.getColumnName(i).toLowerCase(), rsMeta.getColumnLabel(i));
        }
        
        while (columns.next()) {
            Map<String, Object> columnInfo = new LinkedHashMap<>();
            // 添加所有可用元数据
            for (Map.Entry<String, String> entry : columnNameMap.entrySet()) {
                String colName = entry.getKey();
                String displayName = entry.getValue();
                columnInfo.put(displayName, columns.getObject(colName));
            }
            metadataList.add(columnInfo);
        }
        return metadataList;
    }
}