将标题重写为:通过获取ResultSet的id并将其作为java.sql.Array返回
P粉905144514
P粉905144514 2023-09-03 18:10:50
0
1
532
<p>我有以下内容:</p> <pre class="brush:scala;toolbar:false;"> def getIds(name: String): java.sql.Array = { val ids: Array[Integer] = Array() val ps: PreparedStatement = connection.prepareStatement("SELECT id FROM table WHERE name = ?") ps.setString(1, name) val resultSet = ps.executeQuery() while(resultSet.next()) { val currentId = resultSet.getInt(1) ids :+ currentId } return connection.createArrayOf("INTEGER", ids.toArray) } </pre> <p>我的意图是使用这个方法的输出放入另一个PreparedStatement中,使用<code>.setArray(1, <array>)</code></p> <p>但是我得到了以下错误:<code>java.sql.SQLFeatureNotSupportedException</code></p> <p>我正在使用MySQL。已经尝试了INTEGER,INT,BIGINT。但都没有成功。</p>
P粉905144514
P粉905144514

全部回复(1)
P粉265724930

翻译后的内容为:

研究后发现:

所以我的解决方案是创建一个只包含id的临时表:

val idsStatement = connection.prepareStatement(
   "CREATE TEMPORARY TABLE to_delete_ids SELECT id FROM table WHERE name = ?")
idsStatement.setString(1, name)
idsStatement.executeUpdate()

然后与其他语句/查询进行内连接,以达到相同的结果:

val statementDeleteUsingIds = connection.prepareStatement(
    "DELETE to_delete_rows FROM table2 to_delete_rows INNER JOIN to_delete_ids tdi ON tdi.id = to_delete_rows.other_tables_id")
statementDeleteUsingIds.executeUpdate()
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板