簡體   English   中英

如何在沒有 @Query 的情況下使用 Spring Data JDBC 運行自定義 SQL?

[英]How can I run custom SQL with Spring Data JDBC without @Query?

是否有可能運行一些通過 3rd 方工具(例如 jOOQ)生成的自定義 SQL 查詢,並且仍然受益於 Spring Data JDBC 映射功能,即@Column注釋? 我不想使用@Query注釋。

class Model { @Id private Long id; @Column("column") private String prop; }

class MyRepo {
  public Model runQuery() {
    val queryString = lib.generateSQL()
    // run query as if it has been generated by Spring Data JDBC and map
    // results to Model automatically
  }
}

也許JdbcTemplate可以解決您的問題? 具體來說, queryForObject()方法之一可能會引起您的興趣,因為您正在請求單個對象:

class MyRepo {
    private JdbcTemplate jdbcTemplate;

    @Autowired
    MyRepo(JdbcTemplate jdbcTemplate) {
        this.jdbcTemplate = jdbcTemplate;
    }        

    public Model runQuery() {
        val query = lib.generateQuery();
        return jdbcTemplate.queryForObject(query, Model.class);
    }
}

更多信息和其他用例可以在 Spring Guide Accessing Relational Data using JDBC with Spring 中找到

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM