Spring的JDBCTemplate提供了高效执行SQL查询的方法,包括使用IN()子句的查询。以下是一种常见的,但可能并非最佳的方法:
<code class="language-java">StringBuilder jobTypeInClauseBuilder = new StringBuilder(); for(int i = 0; i < jobTypes.length; i++) { Type jobType = jobTypes[i]; if(i != 0) { jobTypeInClauseBuilder.append(','); } jobTypeInClauseBuilder.append(jobType.convert()); }</code>
更优雅的解决方案是使用参数源。此方法包括:
<code class="language-java">Set<Integer> ids = ...; MapSqlParameterSource parameters = new MapSqlParameterSource(); parameters.addValue("ids", ids); List<Foo> foo = getJdbcTemplate().query("SELECT * FROM foo WHERE a IN (:ids)", parameters, getRowMapper());</code>
以上是Spring的JDBCTemplate如何优化IN()查询?的详细内容。更多信息请关注PHP中文网其他相关文章!