„Wenn ein Arbeiter seine Arbeit gut machen will, muss er zuerst seine Werkzeuge schärfen.“ – Konfuzius, „Die Gespräche des Konfuzius. Lu Linggong“
Titelseite > Programmierung > Wie kann ich IN()-SQL-Abfragen effektiv mit Springs JDBCTemplate verwenden?

Wie kann ich IN()-SQL-Abfragen effektiv mit Springs JDBCTemplate verwenden?

Veröffentlicht am 16.11.2024
Durchsuche:481

How can I effectively use IN() SQL queries with Spring's JDBCTemplate?

Effektive IN()-SQL-Abfragen mit Springs JDBCTemplate

Sie haben eine IN()-Abfrage, bei der Sie derzeit eine Klausel mit mehreren Zeilen erstellen of code:

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());
}

Sie suchen nach einem eleganteren Weg, der der Parameterersetzung vorbereiteter Anweisungen ähnelt.

Verwenden einer Parameterquelle

Um die gewünschte Eleganz zu erreichen , können Sie einen Parameter source verwenden:

Set ids = ...;

MapSqlParameterSource parameters = new MapSqlParameterSource();
parameters.addValue("ids", ids);

List foo = getJdbcTemplate().query("SELECT * FROM foo WHERE a IN (:ids)",
     parameters, getRowMapper());

NamedParameterJdbcTemplate

Beachten Sie, dass dies nur funktioniert, wenn getJdbcTemplate() eine Instanz vom Typ NamedParameterJdbcTemplate zurückgibt.

Neuestes Tutorial Mehr>

Haftungsausschluss: Alle bereitgestellten Ressourcen stammen teilweise aus dem Internet. Wenn eine Verletzung Ihres Urheberrechts oder anderer Rechte und Interessen vorliegt, erläutern Sie bitte die detaillierten Gründe und legen Sie einen Nachweis des Urheberrechts oder Ihrer Rechte und Interessen vor und senden Sie ihn dann an die E-Mail-Adresse: [email protected] Wir werden die Angelegenheit so schnell wie möglich für Sie erledigen.

Copyright© 2022 湘ICP备2022001581号-3