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

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

这样就解决了。

相关文章
|
29天前
|
存储 编译器 程序员
掌握Go语言:探索Go语言基础,标记、分隔符、标识符和注释的重要性(6)
掌握Go语言:探索Go语言基础,标记、分隔符、标识符和注释的重要性(6)
|
4月前
|
Go
Go语言导入包:探究点操作符、下划线和别名的妙用
Go语言导入包:探究点操作符、下划线和别名的妙用
31 0
|
4月前
|
算法 编译器 C++
【C++11保姆级教程】深入浅出异常说明符、异常操作符和lambda表达式
【C++11保姆级教程】深入浅出异常说明符、异常操作符和lambda表达式
|
C语言
【C语言】【逻辑非】双感叹号的用法
【C语言】【逻辑非】双感叹号的用法
165 0
|
编译器 C语言 Python
一分钟学Python| 注释、标识符和关键字
一分钟学Python| 注释、标识符和关键字
134 0
一分钟学Python| 注释、标识符和关键字
|
C语言
C语言-语句的用法、规则、使用案例
这篇文章作为C语言基础知识点,介绍C语言常用的几个语句的用法、规则、使用案例。
147 0
|
Java 编译器 程序员
《新版Java开发手册》提到的三目运算符的空指针问题到底是个怎么回事?
解读最新版《Java开发手册-泰山版》提到的三目运算符的空指针问题。
《新版Java开发手册》提到的三目运算符的空指针问题到底是个怎么回事?
三目运算-高级嵌套用法思路教程
三目运算、以及嵌套使用 本文提供全流程,中文翻译。 Chinar 坚持将简单的生活方式,带给世人!(拥有更好的阅读体验 —— 高分辨率用户请根据需求调整网页缩放比例) Chinar —— 心分享...
1365 0
|
Linux Shell
shell编程书写规范与执行方式
执行方式 image.png 创建sh文件 vi 1.sh 开头固定写法(linux默认解析环境) image.png 除了第一行外所有“#”都是注释 image.
997 0