Megosztás a következőn keresztül:


SET ANSI_NULL_DFLT_OFF (Transact-SQL)

A következőkre vonatkozik:SQL ServerAzure SQL DatabaseFelügyelt Azure SQL-példányAzure Synapse AnalyticsElemzési platformrendszer (PDW)SQL Analytics-végpont a Microsoft FabricbenRaktár a Microsoft FabricbenSQL-adatbázis a Microsoft Fabricben

Megváltoztatja a szekció viselkedését, hogy felülírja az új oszlopok alapértelmezett nullitását, ha az adatbázis ANSI null alapértelmezett opciója igaz. További információért az ANSI null alapértelmezett értékének beállításáról lásd: ALTER DATABASE (Transact-SQL).

Transact-SQL szintaxis konvenciók

Szemantika

-- Syntax for SQL Server and Azure SQL Database and Microsoft Fabric
  
SET ANSI_NULL_DFLT_OFF { ON | OFF }
-- Syntax for Azure Synapse Analytics and Parallel Data Warehouse

SET ANSI_NULL_DFLT_OFF OFF

Megjegyzések

Ez a beállítás csak akkor érinti az új oszlopok nullithatóságát, ha az oszlop nullithatósága nincs megadva a CREATE TABLE és ALTER TABLE utasításokban. Alapértelmezettben, amikor a SET ANSI_NULL_DFLT_OFF BEKAPCSOLVA, az ALTER TABLE és a CREATE TABLE utasítások segítségével létrehozott új oszlopok NEM NULLAK, ha az oszlop nullabilitási státusza nincs kifejezetten megadva. A SET ANSI_NULL_DFLT_OFF nem érinti azokat az oszlopokat, amelyeket explicit NULL vagy NOT NULL használatával hoznak létre.

Sem a SET ANSI_NULL_DFLT_OFF, mind a SET ANSI_NULL_DFLT_ON nem lehet egyszerre bekapcsolni. Ha az egyik opció bekapcsolva van, a másik KIKAPCSOLVA. Ezért akár ANSI_NULL_DFLT_OFF, akár SET ANSI_NULL_DFLT_ON bekapcsolható, vagy mindkettő KIKAPCSOLHATÓ. Ha bármelyik opció BEKAPCSOLVA, az a beállítás (SET ANSI_NULL_DFLT_OFF vagy SET ANSI_NULL_DFLT_ON) érvényes. Ha mindkét opció KI van kapcsolva, az SQL Server a sys.databases katalógusnézetben a is_ansi_null_default_on oszlop értékét használja.

A különböző nullability beállításokkal rendelkező adatbázisokban használt Transact-SQL szkriptek megbízhatóbb működtetéséhez jobb mindig megadni a NULL vagy NOT NULL kifejezéseket a CREATE TABLE és ALTER TABLE utasításokban.

A SET ANSI_NULL_DFLT_OFF beállítása végrehajtási vagy futási időben van beállítva, nem parze-időben.

A jelenlegi beállítás megtekintéséhez futtasd le a következő lekérdezést.

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

Permissions

A nyilvános szerepkörhöz tagságra van szükség.

Példák

Az alábbi példa bemutatja mindkét SET ANSI_NULL_DFLT_OFF beállítás hatásait az ANSI null alapértelmezett adatbázis opció esetén.

USE AdventureWorks2022;  
GO  
  
-- Set the 'ANSI null default' database option to true by executing   
-- ALTER DATABASE.  
GO  
ALTER DATABASE AdventureWorks2022 SET ANSI_NULL_DEFAULT ON;  
GO  
-- Create table t1.  
CREATE TABLE t1 (a TINYINT);  
GO  
-- NULL INSERT should succeed.  
INSERT INTO t1 (a) VALUES (NULL);  
GO  
  
-- SET ANSI_NULL_DFLT_OFF to ON and create table t2.  
SET ANSI_NULL_DFLT_OFF ON;  
GO  
CREATE TABLE t2 (a TINYINT);  
GO   
-- NULL INSERT should fail.  
INSERT INTO t2 (a) VALUES (NULL);  
GO  
  
-- SET ANSI_NULL_DFLT_OFF to OFF and create table t3.  
SET ANSI_NULL_DFLT_OFF OFF;  
GO  
CREATE TABLE t3 (a TINYINT) ;  
GO   
-- NULL INSERT should succeed.  
INSERT INTO t3 (a) VALUES (NULL);  
GO  
  
-- This illustrates the effect of having both the database  
-- option and SET option disabled.  
-- Set the 'ANSI null default' database option to false.  
ALTER DATABASE AdventureWorks2022 SET ANSI_NULL_DEFAULT OFF;  
GO  
-- Create table t4.  
CREATE TABLE t4 (a TINYINT) ;  
GO   
-- NULL INSERT should fail.  
INSERT INTO t4 (a) VALUES (NULL);  
GO  
  
-- SET ANSI_NULL_DFLT_OFF to ON and create table t5.  
SET ANSI_NULL_DFLT_OFF ON;  
GO  
CREATE TABLE t5 (a TINYINT);  
GO   
-- NULL insert should fail.  
INSERT INTO t5 (a) VALUES (NULL);  
GO  
  
-- SET ANSI_NULL_DFLT_OFF to OFF and create table t6.  
SET ANSI_NULL_DFLT_OFF OFF;  
GO  
CREATE TABLE t6 (a TINYINT);   
GO   
-- NULL insert should fail.  
INSERT INTO t6 (a) VALUES (NULL);  
GO  
  
-- Drop tables t1 through t6.  
DROP TABLE t1, t2, t3, t4, t5, t6;  
  

Lásd még:

ALTERNATÍV TÁBLÁZAT (Transact-SQL)
CREATE TABLE (Transact-SQL)
SET-utasítások (Transact-SQL)
SET ANSI_NULL_DFLT_ON (Transact-SQL)