Sdílet prostřednictvím


NASTAVTE ANSI_NULL_DFLT_ON (Transact-SQL)

Platí pro:SQL ServerAzure SQL DatabaseSpravovaná instance Azure SQLAzure Synapse AnalyticsAnalytics Platform System (PDW)Koncový bod analýzy SQL v Microsoft FabricSklad v Microsoft FabricDatabáze SQL v Microsoft Fabric

Mění chování relace tak, aby přepsala výchozí nulovatelnost nových sloupců, pokud je výchozí možnost ANSI nul pro databázi nesprávná. Pro více informací o nastavení hodnoty pro ANSI nulový výchozí stav viz ALTER DATABASE (Transact-SQL).

Transact-SQL konvence syntaxe

Syntaxe

-- Syntax for SQL Server and Azure SQL Database and Microsoft Fabric

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

SET ANSI_NULL_DFLT_ON ON

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. Když je SET ANSI_NULL_DFLT_ON zapnutý, nové sloupce vytvořené pomocí příkazů ALTER TABLE a CREATE TABLE umožňují nullové hodnoty, pokud není stav neplatnosti sloupce explicitně uveden. SET ANSI_NULL_DFLT_ON neovlivňuje sloupce vytvořené s explicitním 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 ANSI_NULL_DFLT_ON, nebo oba lze nastavit VYPNUTO. 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ší specifikovat NULL nebo NOT NULL v příkazech CREATE TABLE a ALTER TABLE.

SQL Server Native Client ODBC ovladač a SQL Server Native Client OLE DB Provider pro SQL Server ANSI_NULL_DFLT_ON automaticky nastaví na ON při připojení. Výchozí nastavení pro SET ANSI_NULL_DFLT_ON je VYPNUTO pro připojení z DB-Library aplikací.

Pokud je SET ANSI_DEFAULTS zapnuté, je aktivován SET ANSI_NULL_DFLT_ON.

Nastavení SET ANSI_NULL_DFLT_ON je nastaveno při spuštění nebo běhu a nikoli při parse.

Nastavení SET ANSI_NULL_DFLT_ON se neuplatňuje při vytváření tabulek pomocí příkazu SELECT INTO.

Pro zobrazení aktuálního nastavení tohoto nastavení spusťte následující dotaz.

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

Povolení

Vyžaduje členství ve veřejné roli .

Examples

Následující příklad ukazuje účinky s SET ANSI_NULL_DFLT_ON oběma nastaveními pro výchozí volbu databáze ANSI .

USE AdventureWorks2022;  
GO  
  
-- The code from this point on demonstrates that SET ANSI_NULL_DFLT_ON  
-- has an effect when the 'ANSI null default' for the database is false.  
-- Set the 'ANSI null default' database option to false by executing  
-- ALTER DATABASE.  
ALTER DATABASE AdventureWorks2022 SET ANSI_NULL_DEFAULT OFF;  
GO  
-- Create table t1.  
CREATE TABLE t1 (a TINYINT) ;  
GO   
-- NULL INSERT should fail.  
INSERT INTO t1 (a) VALUES (NULL);  
GO  
  
-- SET ANSI_NULL_DFLT_ON to ON and create table t2.  
SET ANSI_NULL_DFLT_ON ON;  
GO  
CREATE TABLE t2 (a TINYINT);  
GO   
-- NULL insert should succeed.  
INSERT INTO t2 (a) VALUES (NULL);  
GO  
  
-- SET ANSI_NULL_DFLT_ON to OFF and create table t3.  
SET ANSI_NULL_DFLT_ON OFF;  
GO  
CREATE TABLE t3 (a TINYINT);  
GO  
-- NULL insert should fail.  
INSERT INTO t3 (a) VALUES (NULL);  
GO  
  
-- The code from this point on demonstrates that SET ANSI_NULL_DFLT_ON   
-- has no effect when the 'ANSI null default' for the database is true.  
-- Set the 'ANSI null default' database option to true.  
ALTER DATABASE AdventureWorks2022 SET ANSI_NULL_DEFAULT ON  
GO  
  
-- Create table t4.  
CREATE TABLE t4 (a TINYINT);  
GO   
-- NULL INSERT should succeed.  
INSERT INTO t4 (a) VALUES (NULL);  
GO  
  
-- SET ANSI_NULL_DFLT_ON to ON and create table t5.  
SET ANSI_NULL_DFLT_ON ON;  
GO  
CREATE TABLE t5 (a TINYINT);  
GO   
-- NULL INSERT should succeed.  
INSERT INTO t5 (a) VALUES (NULL);  
GO  
  
-- SET ANSI_NULL_DFLT_ON to OFF and create table t6.  
SET ANSI_NULL_DFLT_ON OFF;  
GO  
CREATE TABLE t6 (a TINYINT);  
GO   
-- NULL INSERT should succeed.  
INSERT INTO t6 (a) VALUES (NULL);  
GO  
  
-- Set the 'ANSI null default' database option to false.  
ALTER DATABASE AdventureWorks2022 SET ANSI_NULL_DEFAULT ON;  
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_DEFAULTS (Transact-SQL)
NASTAVTE ANSI_NULL_DFLT_OFF (Transact-SQL)