SET ARITHIGNORE (Transact-SQL)

Berlaku untuk: SQL Server (semua versi yang didukung) Azure SQL Database Azure SQL Managed Instance Azure Synapse Analytics Analytics Platform System (PDW)

Mengontrol apakah pesan kesalahan dikembalikan dari kesalahan luapan atau dibagi dengan nol selama kueri.

tautan topikIkon Konvensi Sintaks Transact-SQL

Sintaks

-- Syntax for SQL Server and Azure SQL Database

SET ARITHIGNORE { ON | OFF }
-- Syntax for Azure Synapse Analytics and Parallel Data Warehouse  

SET ARITHIGNORE OFF

Catatan

Untuk melihat sintaks Transact-SQL untuk SQL Server 2014 dan yang lebih lama, lihat Dokumentasi versi sebelumnya.

Catatan

Sintaks ini tidak didukung oleh kumpulan SQL tanpa server di Azure Synapse Analytics.

Keterangan

Pengaturan SET ARITHIGNORE hanya mengontrol apakah pesan kesalahan dikembalikan. SQL Server mengembalikan NULL dalam perhitungan yang melibatkan kesalahan luapan atau bagi-demi-nol, terlepas dari pengaturan ini. Pengaturan SET ARITHABORT dapat digunakan untuk menentukan apakah kueri dihentikan. Pengaturan ini tidak memengaruhi kesalahan yang terjadi selama pernyataan INSERT, UPDATE, dan DELETE.

Jika SET ARITHABORT atau SET ARITHIGNORE NONAKTIF dan SET ANSI_WARNINGS AKTIF, SQL Server masih mengembalikan pesan kesalahan saat mengalami kesalahan bagi-demi-nol atau luapan.

Pengaturan SET ARITHIGNORE diatur pada waktu eksekusi atau eksekusi dan bukan pada waktu penguraian.

Untuk menampilkan pengaturan saat ini untuk pengaturan ini, jalankan kueri berikut.

DECLARE @ARITHIGNORE VARCHAR(3) = 'OFF';  
IF ( (128 & @@OPTIONS) = 128 ) SET @ARITHIGNORE = 'ON';  
SELECT @ARITHIGNORE AS ARITHIGNORE;  

Izin

Memerlukan keanggotaan dalam peran publik.

Contoh

Contoh berikut menunjukkan penggunaan kedua SET ARITHIGNORE pengaturan dengan kedua jenis kesalahan kueri.

SET ARITHABORT OFF;  
SET ANSI_WARNINGS OFF  
GO  
  
PRINT 'Setting ARITHIGNORE ON';  
GO  
-- SET ARITHIGNORE ON and testing.  
SET ARITHIGNORE ON;  
GO  
SELECT 1 / 0 AS DivideByZero;  
GO  
SELECT CAST(256 AS TINYINT) AS Overflow;  
GO  
  
PRINT 'Setting ARITHIGNORE OFF';  
GO  
-- SET ARITHIGNORE OFF and testing.  
SET ARITHIGNORE OFF;  
GO  
SELECT 1 / 0 AS DivideByZero;  
GO  
SELECT CAST(256 AS TINYINT) AS Overflow;  
GO  

Contoh: Azure Synapse Analytics and Analytics Platform System (PDW)

Contoh berikut menunjukkan kesalahan dibagi dengan nol dan luapan. Contoh ini tidak mengembalikan pesan kesalahan untuk kesalahan ini karena ARITHIGNORE NONAKTIF.

-- SET ARITHIGNORE OFF and testing.  
SET ARITHIGNORE OFF;  
SELECT 1 / 0 AS DivideByZero;  
SELECT CAST(256 AS TINYINT) AS Overflow;  

Lihat juga

Pernyataan SET (Transact-SQL)
SET ARITHABORT (Transact-SQL)