Poznámka:
Přístup k této stránce vyžaduje autorizaci. Můžete se zkusit přihlásit nebo změnit adresáře.
Přístup k této stránce vyžaduje autorizaci. Můžete zkusit změnit adresáře.
Platí pro:SQL Server
Azure SQL Database
Spravovaná instance Azure SQL
Azure Synapse Analytics
Analytics Platform System (PDW)
Koncový bod analýzy SQL v Microsoft Fabric
Sklad v Microsoft Fabric
Databáze SQL v Microsoft Fabric
Mění chování relace tak, aby přepsala výchozí nulovatelnost nových sloupců, když je výchozí volba ANSI null pro databázi správná. Pro více informací o nastavení hodnoty pro ANSI null default viz ALTER DATABASE (Transact-SQL).
Syntaxe
-- 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
Poznámky
Toto nastavení ovlivňuje nulovatelnost nových sloupců pouze tehdy, když neplatnost sloupce není specifikována v příkazech CREATE TABLE a ALTER TABLE. Ve výchozím nastavení, když je NASTAVIT ANSI_NULL_DFLT_OFF ZAPNUTO, nové sloupce vytvořené pomocí příkazů ALTER TABLE a CREATE TABLE NEJSOU NULL, pokud není explicitně specifikován stav neplatnosti sloupce. SET ANSI_NULL_DFLT_OFF neovlivňuje sloupce vytvořené použitím explicitního NULL nebo NOT NULL.
SET ANSI_NULL_DFLT_OFF i SET ANSI_NULL_DFLT_ON nelze nastavit současně. Pokud je jedna možnost zapnuta, druhá možnost je vypnutá. Proto lze buď nastavit ANSI_NULL_DFLT_OFF nebo SET ANSI_NULL_DFLT_ON, nebo oba mohou být VYPNUTÉ. Pokud je některá z možností ZAPNUTÁ, toto nastavení (SET ANSI_NULL_DFLT_OFF nebo SET ANSI_NULL_DFLT_ON) se aktivuje. Pokud jsou obě možnosti vypnuté, SQL Server použije hodnotu sloupce is_ansi_null_default_on v katalogu sys.databases .
Pro spolehlivější provoz Transact-SQL skriptů používaných v databázích s různými nastaveními neplatnosti je lepší vždy specifikovat NULL nebo NOT NULL v příkazech CREATE TABLE a ALTER TABLE.
Nastavení SET ANSI_NULL_DFLT_OFF je nastaveno při spuštění nebo běhu a nikoli při parse.
Pro zobrazení aktuálního nastavení tohoto nastavení spusťte následující dotaz.
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;
Povolení
Vyžaduje členství ve veřejné roli.
Examples
Následující příklad ukazuje účinky s SET ANSI_NULL_DFLT_OFF oběma nastaveními pro výchozí volbu databáze ANSI.
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;
Viz také
ZMĚNIT TABULKU (Transact-SQL)
VYTVOŘIT TABULKU (Transact-SQL)
Příkazy SET (Transact-SQL)
NASTAVTE ANSI_NULL_DFLT_ON (Transact-SQL)