ATUR ARITHIGNORE (SQL transact)
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.
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)
ATUR ARITHABORT (SQL bertransaksi)
