[英]JDBC PreparedStatement with aggregate function on dynamic column in Select clause
我试图提供一个实用程序,可以在表的每一列中获取最大数据长度。
执行以下准备好的语句。
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.