SpringDataJpa存储过程调用

发布于 2022-09-11 15:22:10 字数 1311 浏览 19 评论 0

SpringDataJpa通过Repository怎么调用没有OUT参数的存储过程?

我的存储过程是这么定义的

delimiter $$
create PROCEDURE nearbyMarket(IN latitude DECIMAL(9,6), IN longitude DECIMAL(9,6))
BEGIN
DECLARE marketId INT(20);
SELECT id INTO marketId FROM (SELECT min(pow(latitude - a.latitude, 2) + pow(longitude - a.longitude, 2)) AS distance, a.* FROM account_markets a) AS b;
SELECT * FROM account_markets WHERE id = marketId;
END;
$$
delimiter ;
@Entity
@NamedStoredProcedureQuery(
        name = "Markets.nearById",
        procedureName = "nearbyMarketId",
        resultClasses = [AccountMarketsEntity::class],
        parameters = [
        StoredProcedureParameter(name = "latitude", mode = ParameterMode.IN, type = BigDecimal::class),
        StoredProcedureParameter(name = "longitude", mode = ParameterMode.IN, type = BigDecimal::class)
        ]
)
@Table(name = "account_markets")
@DynamicInsert
@DynamicUpdate
class AccountMarketsEntity()

# Repository中
@Procedure(name = "Markets.nearBy")
    fun retrieveNearbyMarketByLocation(@Param("latitude") latitude: BigDecimal, @Param("longitude") longitude: BigDecimal): AccountMarketsEntity?

执行程序时retrieveNearbyMarketByLocation方法被当作方法查询了,提示AccountMarketsEntity没有retrieveNearbyMarketByLocation这个属性

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文