首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何从camel-sql组件中获取表元数据

如何从camel-sql组件中获取表元数据
EN

Stack Overflow用户
提问于 2016-08-30 09:19:51
回答 1查看 154关注 0票数 0

我正在寻找一种使用camel-sql组件获取给定表名的所有列元数据的方法。

尽管它在幕后使用了spring-jdbc,但我看不到获得ResultSetMetaData的方法。

EN

回答 1

Stack Overflow用户

发布于 2017-03-19 22:44:44

我无法找到从camel-sql组件获取列详细信息的直接方法,到目前为止,我设法使用spring jdbc模板和数据源获取信息。

代码语言:javascript
复制
public List<String> getColumnNamesFromTable(final TableData tableData) throws MetaDataAccessException {
        final List<String> columnNames = new ArrayList<String>();
        JdbcTemplate jdbcTemplate = new JdbcTemplate(dataSource);
        StringBuilder query = new StringBuilder();
        query.append("SELECT * FROM ").append(SINGLE_BLANK_SPACE);
        query.append(tableData.getSchemaName());
        query.append(tableData.getTableName()).append(SINGLE_BLANK_SPACE);
        query.append("WHERE rownum < 0");

        jdbcTemplate.query(query.toString(), new ResultSetExtractor<Integer>() {
            @Override
            public Integer extractData(ResultSet rs) throws SQLException, DataAccessException {
                ResultSetMetaData rsmd = rs.getMetaData();
                int columnCount = rsmd.getColumnCount();
                for (int i = 1; i <= columnCount; i++) {
                    columnNames.add(rsmd.getColumnName(i).toUpperCase());
                }
                return columnCount;
            }
        });
        return columnNames;
    }
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/39217449

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档