[英]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.