首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >JDBC :从元数据获取数组的类型

JDBC :从元数据获取数组的类型
EN

Stack Overflow用户
提问于 2017-03-21 14:21:30
回答 1查看 1.4K关注 0票数 1

是否可以从JDBC元数据结构中获取数组列的类型?

代码语言:javascript
复制
re = openedConnection.getMetaData().getColumns(...)
while (rs.next())
{
  final String columnName = rs.getString("COLUMN_NAME");
  final int columnType = rs.getInt("DATA_TYPE");
  ...

类型返回数组但是数组是什么(int,text,数值.)?

理想情况下,数据库是独立的(Oracle和Postgres支持这一点,对于MySQL或Server并不确定)

EN

回答 1

Stack Overflow用户

发布于 2017-03-21 16:00:12

使用java.sql.ResultSetMetaData.getColumnTypeName()

Oracle安装

代码语言:javascript
复制
CREATE OR REPLACE TYPE random_array IS TABLE OF VARCHAR2(42);
/

Java

代码语言:javascript
复制
Class.forName("oracle.jdbc.OracleDriver");

Connection con = DriverManager.getConnection(
    "jdbc:oracle:thin:@localhost:1521:orcl",
    "username",
    "password"
);

PreparedStatement st = con.prepareStatement(
    "SELECT random_array( 'a', 'b', 'c' ) AS array FROM DUAL"
);

ResultSet rs = st.executeQuery();
while( rs.next() )
{
  String type = rs.getMetaData().getColumnTypeName(1);
  String[] data = (String[]) rs.getArray(1).getArray();
  System.out.println( type + ": " + Arrays.toString( data ) );
}

st.close();
con.close();

输出

代码语言:javascript
复制
SCHEMA_NAME.RANDOM_ARRAY: [a, b, c]

如果您想回到Oracle并找到可以使用的集合元素的类型:

代码语言:javascript
复制
SELECT ELEM_TYPE_NAME,
       LENGTH,
       PRECISION,
       SCALE
FROM   ALL_COLL_TYPES
WHERE  TYPE_NAME = 'RANDOM_ARRAY'
AND    OWNER     = 'SCHEMA_NAME';

其中产出:

代码语言:javascript
复制
ELEM_TYPE_NAME LENGTH PRECISION SCALE
-------------- ------ --------- -----
VARCHAR2           42
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/42929774

复制
相关文章

相似问题

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