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

这样就解决了。

相关文章
|
9月前
|
程序员 编译器 C++
【实用编程技巧】不想改bug?初学者必须学会使用的报错函数assert!(断言函数详解)
【实用编程技巧】不想改bug?初学者必须学会使用的报错函数assert!(断言函数详解)
73 2
|
Java 编译器
【JavaSE专栏66】使用instanceof关键字,验证显隐式类型转换
【JavaSE专栏66】使用instanceof关键字,验证显隐式类型转换
|
7月前
|
存储 前端开发 JavaScript
条件判断的模式问题之如果混淆了断言和卫述如何解决
条件判断的模式问题之如果混淆了断言和卫述如何解决
|
7月前
|
IDE 开发工具 Python
python语法错误关键字使用错误
【7月更文挑战第9天】
86 6
|
8月前
|
Java
崩溃!Java 逻辑运算符,让你重新认识基本语法!
【6月更文挑战第14天】Java中的逻辑运算符“&&”、“||”和“!”用于构建复杂的逻辑结构。例如,“&&”要求两边操作数均为真,表达式才为真;“||”只需一个操作数为真即为真;“!”是对布尔值取反。通过这些运算符,我们可以编写条件判断和逻辑推理,如示例所示,它们在程序设计中扮演着关键角色,使程序能根据不同条件作出相应反应。理解和熟练使用逻辑运算符对于编写智能灵活的程序至关重要。
48 1
|
9月前
|
C语言
C语言中的条件控制循环:深入解析与实战应用
C语言中的条件控制循环:深入解析与实战应用
117 1
|
9月前
|
C语言 Python
【Python指南 | 第六篇】条件控制语句、循环语句,这一篇就够了
【Python指南 | 第六篇】条件控制语句、循环语句,这一篇就够了
113 0
|
9月前
|
算法 编译器 C++
【C++11保姆级教程】深入浅出异常说明符、异常操作符和lambda表达式
【C++11保姆级教程】深入浅出异常说明符、异常操作符和lambda表达式
145 0
feof用法重点详解(易被误用判断文件结束!!!)
feof用法重点详解(易被误用判断文件结束!!!)
|
测试技术
测试中进行断言是什么意思?底层原理是什么?
测试中进行断言是什么意思?底层原理是什么?
1505 0