开发者社区> 技术小胖子> 正文
阿里云
为了无法计算的价值
打开APP
阿里云APP内打开

在SQLSERVER中,决定当前会话的SET配置(翻译)[转]

简介:
+关注继续查看

出处:http://www.cnblogs.com/fly_zj/archive/2010/07/07/1772818.html

原文为Determining SET Options for a Current Session in SQL Server

 

问题?

对于每个连接到SQLSERVER上的会话(Session),用户能够设置SET选项来影响查询的结果和SQLSERVER潜在的行为,有些选项能通过GUI来设置,有些需要

通过SET 命令来设置,使用GUI非常方便知道某个设置开启与否,但是怎样获取当前会话的所有选项设置呢?

 

解决方案

SQLSERVER 提供许多内建的元数据函数,其中一个是@@OPTIONS,能获取当前会话(session)的当前值。每个成功的连接都会有一个默认的值,其值也能

被其它线程覆写。

下面这张表列出每个配置选项对应的值,及其详细的描述(摘录自SQLSERVER 2005帮助文档)

 

配置

说明

1

DISABLE_DEF_CNST_CHK

控制临时或延迟约束检查。

2

IMPLICIT_TRANSACTIONS

对于 DBLIB 网络库连接,控制执行语句时是否隐式启动事务。

IMPLICIT_TRANSACTIONS 设置对 ODBC 或 OLEDB 连接没有影响。

4

CURSOR_CLOSE_ON_COMMIT

控制执行提交操作后游标的行为。

8

ANSI_WARNINGS

控制聚合警告中的截断和 NULL。

16

ANSI_PADDING

控制固定长度变量的填充。

32

ANSI_NULLS

使用相等运算符时控制 NULL 处理。

64

ARITHABORT

在查询执行过程中出现溢出或被零除错误时终止查询。

128

ARITHIGNORE

在查询过程中出现溢出或被零除错误时返回 NULL。

256

QUOTED_IDENTIFIER

对表达式进行求值时区别单引号和双引号。

512

NOCOUNT

关闭执行每个语句后返回的报告受影响的行数的消息。

1024

ANSI_NULL_DFLT_ON

将会话的行为更改为使用 ANSI 兼容的空性。未显式定义为空性的新列允许使用空值。

2048

ANSI_NULL_DFLT_OFF

将会话的行为更改为不使用 ANSI 兼容的空性。未显式定义为空性的新列不允许使用空值。

4096

CONCAT_NULL_YIELDS_NULL

将 NULL 值与字符串串联时返回 NULL。

8192

NUMERIC_ROUNDABORT

表达式中出现精度降低时生成错误。

16384

XACT_ABORT

如果 Transact-SQL 语句产生运行时错误,则回滚事务。

 

 

在前一章Reproducing Query Execution Plan Performance Problems中谈到了SET 选择是如何影响到查询结果和性能的,所以SET 命令对于当前会话的设置非常

有用,为了得到当前会话的配置值,可以运行如下的SELECT语句

SELECT @@OPTIONS
该语句会返回一整形值代表上表格中所有选项值的与。为了更好的理解这整形值的含义,可运行接下来的按位与操作,看看哪个SET选项被开启:
DECLARE @options INT

SELECT @options = @@OPTIONS

PRINT @options
IF ( (1 & @options) = 1 ) PRINT 'DISABLE_DEF_CNST_CHK'
IF ( (2 & @options) = 2 ) PRINT 'IMPLICIT_TRANSACTIONS'
IF ( (4 & @options) = 4 ) PRINT 'CURSOR_CLOSE_ON_COMMIT'
IF ( (8 & @options) = 8 ) PRINT 'ANSI_WARNINGS'
IF ( (16 & @options) = 16 ) PRINT 'ANSI_PADDING'
IF ( (32 & @options) = 32 ) PRINT 'ANSI_NULLS'
IF ( (64 & @options) = 64 ) PRINT 'ARITHABORT'
IF ( (128 & @options) = 128 ) PRINT 'ARITHIGNORE'
IF ( (256 & @options) = 256 ) PRINT 'QUOTED_IDENTIFIER'
IF ( (512 & @options) = 512 ) PRINT 'NOCOUNT'
IF ( (1024 & @options) = 1024 ) PRINT 'ANSI_NULL_DFLT_ON'
IF ( (2048 & @options) = 2048 ) PRINT 'ANSI_NULL_DFLT_OFF'
IF ( (4096 & @options) = 4096 ) PRINT 'CONCAT_NULL_YIELDS_NULL'
IF ( (8192 & @options) = 8192 ) PRINT 'NUMERIC_ROUNDABORT'
IF ( (16384 & @options) = 16384 ) PRINT 'XACT_ABORT' 

 

上面代码执行的结果为:

 

QQ截图未命名

 

说明:@@OPTIONS返回5496,接下来每行的是当前会话(Session)开启的配置选项。

当我们设置SET NOCOUNT ON,其比特值(bit value)是512,来看看@@OPTIONS值的变化,现在的值为5496+512=6008.运行如下的代码:

 

SET NOCOUNT ON

DECLARE @options INT

SELECT @options = @@OPTIONS

PRINT @options
IF ( (1 & @options) = 1 ) PRINT 'DISABLE_DEF_CNST_CHK'
IF ( (2 & @options) = 2 ) PRINT 'IMPLICIT_TRANSACTIONS'
IF ( (4 & @options) = 4 ) PRINT 'CURSOR_CLOSE_ON_COMMIT'
IF ( (8 & @options) = 8 ) PRINT 'ANSI_WARNINGS'
IF ( (16 & @options) = 16 ) PRINT 'ANSI_PADDING'
IF ( (32 & @options) = 32 ) PRINT 'ANSI_NULLS'
IF ( (64 & @options) = 64 ) PRINT 'ARITHABORT'
IF ( (128 & @options) = 128 ) PRINT 'ARITHIGNORE'
IF ( (256 & @options) = 256 ) PRINT 'QUOTED_IDENTIFIER'
IF ( (512 & @options) = 512 ) PRINT 'NOCOUNT'
IF ( (1024 & @options) = 1024 ) PRINT 'ANSI_NULL_DFLT_ON'
IF ( (2048 & @options) = 2048 ) PRINT 'ANSI_NULL_DFLT_OFF'
IF ( (4096 & @options) = 4096 ) PRINT 'CONCAT_NULL_YIELDS_NULL'
IF ( (8192 & @options) = 8192 ) PRINT 'NUMERIC_ROUNDABORT'
IF ( (16384 & @options) = 16384 ) PRINT 'XACT_ABORT' 


上面代码执行的结果为:

QQ截图未命名

 

看看当SET NOCOUNT ON ,SET QUOTED_IDENTIFIFER OFF的结果

SET NOCOUNT ON
SET QUOTED_IDENTIFIER OFF

DECLARE @options INT

SELECT @options = @@OPTIONS

PRINT @options
IF ( (1 & @options) = 1 ) PRINT 'DISABLE_DEF_CNST_CHK'
IF ( (2 & @options) = 2 ) PRINT 'IMPLICIT_TRANSACTIONS'
IF ( (4 & @options) = 4 ) PRINT 'CURSOR_CLOSE_ON_COMMIT'
IF ( (8 & @options) = 8 ) PRINT 'ANSI_WARNINGS'
IF ( (16 & @options) = 16 ) PRINT 'ANSI_PADDING'
IF ( (32 & @options) = 32 ) PRINT 'ANSI_NULLS'
IF ( (64 & @options) = 64 ) PRINT 'ARITHABORT'
IF ( (128 & @options) = 128 ) PRINT 'ARITHIGNORE'
IF ( (256 & @options) = 256 ) PRINT 'QUOTED_IDENTIFIER'
IF ( (512 & @options) = 512 ) PRINT 'NOCOUNT'
IF ( (1024 & @options) = 1024 ) PRINT 'ANSI_NULL_DFLT_ON'
IF ( (2048 & @options) = 2048 ) PRINT 'ANSI_NULL_DFLT_OFF'
IF ( (4096 & @options) = 4096 ) PRINT 'CONCAT_NULL_YIELDS_NULL'
IF ( (8192 & @options) = 8192 ) PRINT 'NUMERIC_ROUNDABORT'
IF ( (16384 & @options) = 16384 ) PRINT 'XACT_ABORT' 


上面代码运行的结果为:

QQ截图未命名

已经排除QUOTED_IDENTIFIER选项了。

 

总结

这个简单的元数据函数(@@OPTIONS)能够给你非常多的有关当前会话(Session)配置信息,通过该元数据函数,你能知晓用户会话的配置设置,

也可以确保代码运行符合设想而开启或关闭某个选项。



    本文转自 Fanr_Zh 博客园博客,原文链接:http://www.cnblogs.com/Amaranthus/archive/2012/10/27/2742786.html,如需转载请自行联系原作者





版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
【laravel】call_user_func_array在框架的使用
【laravel】call_user_func_array在框架的使用
41 0
Java中包装类(Wrapper)的使用
Java中包装类(Wrapper)的使用
86 0
RDS SQL Server - 最佳实践 - 高CPU使用率系列之非SARG查询
# 摘要 阿里云RDS SQL Server客户遇到最多的一个问题便是高CPU使用率导致导致SQL Server服务响应缓慢,查询超时,甚至服务挂起僵死。本系列文章第四篇分析非SARG查询导致CPU的高利用率的解决之道。 # 问题引入 “鸟啊,你听说过RDBMS的非SARG查询语句吗?我还是今天第一次听说呢!”。老鸟有些不解的问菜鸟。 “哈哈,鸟哥,孤陋寡闻,土鳖了吧。它可是导致RDBMS
3116 0
Webstorm配置CSS/SCSS自动补全兼容前缀autoprefixer插件
关于Autoprefixer Autoprefixer是一个后处理程序,不象Sass以及Stylus之类的预处理器。它适用于普通的CSS,可以实现css3代码自动补全。也可以轻松跟Sass,LESS及Stylus集成,在CSS编译前或编译后运行。
2343 0
webconfig中配置各种数据库的连接字符串(转)
一、在appSettings配置                                                      二、在connectionStrings配置                       ...
1041 0
webstorm配置scss自动编译路径
webstorm支持sass的同步编译,也就是即写即编译,并且可以指定编译后的css的目录. 本文使用的webstorm为8.0版本 scss安装:http://www.w3cplus.com/sassguide/install.
757 0
Configuring Java CAPS for SSL Support - Adapters
Configuring Java CAPS for SSL Support Previous: OpenSSL Project Next: KeyStores and TrustStores SSL and Adapters The use of SSL with HTTP, LDAP, ...
850 0
Configuring Java CAPS for SSL Support - Program
Configuring Java CAPS for SSL Support Previous: Public Keys, Private Keys, and Certificates Next: OpenSSL Project Keytool Program The keytool pro...
796 0
21114
文章
0
问答
文章排行榜
最热
最新
相关电子书
更多
低代码开发师(初级)实战教程
立即下载
阿里巴巴DevOps 最佳实践手册
立即下载
冬季实战营第三期:MySQL数据库进阶实战
立即下载