NOT NULL Constraints with MariaDB Xpand

Overview

MariaDB Xpand supports NOT NULL constraints to ensure that a column's value is not set to NULL:

  • When a column is declared with a NOT NULL constraint, Xpand rejects operations that would write a NULL value to the column

Compatibility

  • MariaDB Xpand 5.3

  • MariaDB Xpand 6.0

  • MariaDB Xpand 6.1

CREATE TABLE

CREATE TABLE and NOT NULL Constraints

With MariaDB Xpand, the CREATE TABLE statement can be used to create a new table with a NOT NULL constraint on one or more columns:

CREATE TABLE hq_sales.invoices (
   invoice_id BIGINT UNSIGNED NOT NULL,
   branch_id INT NOT NULL,
   customer_id INT,
   invoice_date DATETIME(6),
   invoice_total DECIMAL(13, 2),
   payment_method ENUM('NONE', 'CASH', 'WIRE_TRANSFER', 'CREDIT_CARD', 'GIFT_CARD'),
   PRIMARY KEY (invoice_id)
);

ALTER TABLE

ALTER TABLE .. MODIFY COLUMN .. NOT NULL

With MariaDB Xpand, the ALTER TABLE statement can be used to add the NOT NULL constraint to a column using the MODIFY COLUMN clause:

ALTER TABLE hq_sales.invoices
   MODIFY COLUMN customer_id INT NOT NULL;

ALTER TABLE .. MODIFY COLUMN .. NULL

With MariaDB Xpand, the ALTER TABLE statement can be used to remove the NOT NULL constraint from a column using the MODIFY COLUMN clause:

ALTER TABLE hq_sales.invoices
   MODIFY COLUMN customer_id INT NULL;

Special Cases

  • Xpand does not raise an error if a NOT NULL column specifies NULL as the default value, but the column is treated as NOT NULL