繁体   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