调用SQLserver存储过程时,Spring JdbcTemplate非常慢

问题描述

我正在使用JdbcTemplate.execute()调用与SQLServer数据库连接的SP。 使用相同的参数,当我直接在SQL Server Management Studio中执行SP时,它会在1秒钟内完成,但是当我在Java中使用JdbcTemplate时,它在几分钟内执行会导致严重的性能问题。

请注意,存储过程包含“ SET ANSI_NULLS ON”和“ SET QUOTED_IDENTIFIER ON”

解决方法

经过一些测试,我终于发现问题在于我的SP中的空白值判断:

我有一些SP的默认参数并将它们设置为@A nvarchar(255)='',然后在逻辑期间我需要将它们用作逻辑条件:if(@A不为null并且rtrim(ltrim( @A))'') 就这么简单,它在Management Studio中完全可以正常工作。

将init更改为@A nvarchar(255)并使用if(@A不为null)后,它还会在JdbcTemplate中返回结果...因此JdbcTemplate应该有一些内部逻辑来执行该空检查,但是我不确定原因和方式。

相关问答

错误1:Request method ‘DELETE‘ not supported 错误还原:...
错误1:启动docker镜像时报错:Error response from daemon:...
错误1:private field ‘xxx‘ is never assigned 按Alt...
报错如下,通过源不能下载,最后警告pip需升级版本 Requirem...