mssql sqlserver ARITHABORT 属性简介及举例应用


摘要:
下文讲述sqlserver中 ARITHABORT 属性的相关功能及举例说明


一、ARITHABORT 属性功能说明

ARITHABORT 设置为ON时,当出现溢出或被零整除时,会终止查询,
默认情况下:SSMS中 ARITHABORT 属性为ON
1 .SET ARITHABORT 设置为 ON, SET ANSI_WARNINGS 设置为 ON 当出现错误时候,导致查询终止
2 .SET ARITHABORT 设置为 ON, SET ANSI_WARNINGS 设置为 OFF 出现错误导致批处理终止,如果发生在事务内,则会回滚事务,如果此时将 SET ARITHABORT 设置为 OFF,
则显示一条警告结果,并将 null赋值给运算结果,如果待赋值变量存在值,则直接输出原变量数值,程序继续向下运行
3 .SET ARITHABORT 设置为 OFF, SET ANSI_WARNINGS 设置为 OFF ,当出现错误时,显示一条警告消息,并将 null赋值给运算结果,如果待赋值变量存在值,则直接输出原变量数值

二、ARITHABORT 属性使用举例

 create table test (keyId int identity,qty int,qty2 int)
 go
 
 insert into test(qty)values(1),(2),(0),(3)
 go
 
 set ARITHABORT OFF
 set ANSI_WARNINGS OFF
 
 update test set qty2 = keyId/qty
  select * from test 
 go
 
 truncate table test
 drop table test 
mssql_sqlserver_ARITHABORT_关键字举例应用

mssql_sqlserver_ARITHABORT_关键字举例应用