Das JDBCTemplate von Spring bietet eine Möglichkeit, SQL-Abfragen effizient auszuführen, einschließlich Abfragen mit der IN()-Klausel. Hier ist ein gängiger, aber wahrscheinlich nicht optimaler Ansatz:
<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>
Eine elegantere Lösung ist die Verwendung von Parameterquellen. Diese Methode beinhaltet:
<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>
Das obige ist der detaillierte Inhalt vonWie kann Springs JDBCTemplate IN()-Abfragen optimieren?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!