【解决方案 十六】关键字 '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

这样就解决了。

发布了246 篇原创文章 · 获赞 124 · 访问量 19万+

猜你喜欢

转载自blog.csdn.net/sinat_33087001/article/details/104267668