繁体   English   中英

JDBC PreparedStatement在Select子句中的动态列上具有聚合函数

[英]JDBC PreparedStatement with aggregate function on dynamic column in Select clause

我试图提供一个实用程序,可以在表的每一列中获取最大数据长度。

  1. 我在列表中有列的列表。
  2. 我遍历每个列表。
  3. 执行以下准备好的语句。

     String sql = "select max(datalength(?)) from Positions"; for(Iterate over list of column names) { preparedStatement.setString(1, StringUtils.trim(columnName)); ResultSet rs = preparedStatement.executeQuery(); if (rs.next()) { int length1 = rs.getInt(1); //print column name and max data length } } 

似乎带有max函数的准备好的语句使动态列不起作用。 它给出了不正确的值。

可以在select子句中使用动态列准备语句。

请尝试以下。

Select max(length(<column_name>)) as max_length

From <Table_name>; 

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM