【解决方案 十六】关键字 'with' 附近有语法错误

这个事儿的背景吧就是因为加锁查询速度太慢,于是让咱优化,至少先通过使用with(nolock)来解决查询慢的问题,这么个事儿说来也简单对伐,但是影响范围特别大,因为要优化的这个存储过程是个动态存储过程,有70多个操作行为DAO调用到了这个存储过程,可谓牵一发而动全身。

报错了!

一开始自信满满,参照了一篇文章了解了解with(nolock)咋玩儿

SQL Server 中WITH (NOLOCK)浅析 https://www.cnblogs.com/kerrycode/p/3946268.html

想着就直接在存储过程最后拼一个with(nolock)呗,类似这样:

SELECT * FROM TML where Name='maolintian' and age=29 with(nolock)

结果一下报了一个大错,直接影响了平台的功能,大家的标准功能都不好使了。

消息 319,级别 15,状态 1,第 1 行
关键字 'with' 附近有语法错误。如果此语句是公用表表达式、
xmlnamespaces 子句或者更改跟踪上下文子句,那么前一个语句必须以分号结尾。

于是使用如下方法来处理。

如何处理

怎么排查呢?在杰哥大佬的帮助下使用print先把sql打出来看看:print @strSQL,使用完该语句打印出来后又查了下问题:

  1. 首先重新新建一个存储过程,起个别名,在里边加入print @strSQL来打印,防止被影响了。
  2. 然后让杰哥看了下原来是with(nolock)后置了。
  3. 排查好问题后,最后删除新建的这个存储过程。

调整后存储过程应该为:

SELECT * FROM TML  with(nolock)  where Name='maolintian' and age=29

这样就解决了。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

存在morning

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值