gpt4 book ai didi

mysql - Postgres JDBC 的表名别名

转载 作者:可可西里 更新时间:2023-11-01 08:26:51 28 4
gpt4 key购买 nike

我们有一个使用表名并对列进行操作的方法。此方法以前用于 MySQL,但在 postgres 中将空白作为表名。

我在下面提供了一个非常简单的 SQL 查询来演示。

select * from ((select * from users2 limit 1) 
union (select * from users limit 1)) as sub;

演示获取表名的代码。

 try{
connection = DriverManager.getConnection(
connectionURL, dbUserName,
dbPassword);



PreparedStatement psmt = connection.prepareStatement("select * from ((select * from users2 limit 1) union (select * from users limit 1)) as sub");

ResultSet rs = psmt.executeQuery();

ResultSetMetaData metaData = rs.getMetaData();

System.out.println("Table Name");
System.out.println("----------");

System.out.println(metaData.getTableName(1));


}

在连接参数为 ?useOldAliasMetadataBehavior=true 的 MYSQL 中,它将表名打印为 sub。但在 Postgres 中,它打印出一个空字符串。

我什至尝试了如下递归 CTE。

with sub as((select * from users2 limit 1) 
union (select * from users limit 1)) select * from sub;

问题

  • 如何获取表名作为别名?在 MYSQL 中,它由一个参数控制,是否有与 Postgres 等效的东西?
  • 是否可以更改查询中的任何内容,以便结果集元数据返回别名表名。

请注意,我不想在这里查看,这只是一次使用。我也无法修复底层方法,因为它会导致对所有使用代码的代码更改。

有什么快速的方法可以解决这个问题吗?

最佳答案

ResultSetMetaData.getTableName 不应该返回表的别名,它应该返回实际的源表名称(如果可用)。这也是为什么在 MySQL 中您需要显式使用 useOldAliasMetadataBehavior=true 来获取此信息的原因。

从 JDBC 规范的角度来看,PostgreSQL 的行为更好。联合的列不能有表名,因为结果集中单个列中的值可能来自完全不同的表。据我所知,PostgreSQL 没有返回您期望的信息的选项。

关于mysql - Postgres JDBC 的表名别名,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34590432/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com