This page describes how to enable Spanner columnar engine on a database, table, or index, and accelerate file format generation.
Enable Spanner columnar engine (Google SQL)
Spanner columnar engine is enabled using a SET OPTIONS clause
with the columnar_policy option. You can apply this option when you create or
alter DATABASE, TABLE, or INDEX schema objects. SEARCH INDEX and
VECTOR INDEX schema objects are never in columnar format.
Tables and indexes inherit the columnar_policy specified at the database level.
The columnar_policy option has the following flags:
'enabled'or'disabled'turns the columnar engine on or off for the specific schema object.NULL(default) uses the columnar engine policy from the parent object, if one exists.NULLclears previous settings on a table object.
You can also omit OPTIONS to inherit the columnar_policy from the parent
object.
The following example shows how to:
- Create a database with the columnar policy enabled.
- Define a
Singerstable that inherits the columnar policy from the database (omit thecolumnar_policy = NULLfor the table option). - Define a
Concertstable with the columnar policy explicitly disabled.
CREATE DATABASE Music;
ALTER DATABASE Music SET OPTIONS (columnar_policy = 'enabled');
CREATE TABLE Singers(
SingerId INT64 NOT NULL,
FirstName STRING(1024),
LastName STRING(1024),
BirthDate DATE,
Status STRING(1024),
LastUpdated TIMESTAMP,)
PRIMARY KEY(SingerId);
CREATE TABLE Concerts(
VenueId INT64 NOT NULL,
SingerId INT64 NOT NULL,
ConcertDate DATE NOT NULL,
BeginTime TIMESTAMP,
EndTime TIMESTAMP,)
PRIMARY KEY(VenueId, SingerId, ConcertDate),
OPTIONS (columnar_policy = 'disabled');
You can also use ALTER TABLE with the SET OPTIONS clause to enable or
disable the columnar_policy on a table. The following example shows how to
disable the policy in the Singers table:
ALTER TABLE Singers SET OPTIONS (columnar_policy = 'disabled');
Enable Spanner columnar engine (Postgres)
You can enable the Spanner columnar engine for all tables and indexes by issuing this statement:
ALTER DATABASE db_name SET spanner.columnar_policy TO enabled
You can enable the Spanner columnar engine for specific tables and
indexes by adding the COLUMNAR POLICY enabled option when creating or
altering a TABLE or INDEX schema object. SEARCH INDEX and VECTOR INDEX
schema objects are never in columnar format.
Tables and indexes inherit the COLUMNAR POLICY specified at the database
level.
The COLUMNAR POLICY keyword option has the following possible values:
enabledordisabledturns the columnar engine on or off for the specific schema object.NULLuses the columnar engine policy from the parent object, if one exists.NULLclears the previous setting on a table or index schema object.
The following example shows how to:
- Create a database with the columnar policy enabled.
- Define a
Singerstable that inherits the columnar policy from the database (omit thecolumnar_policy = NULLfor the table option). - Define a
Concertstable with the columnar policy explicitly disabled.
CREATE DATABASE Music;
ALTER DATABASE "Music" SET spanner.columnar_policy TO enabled;
CREATE TABLE Singers(
SingerId bigint PRIMARY KEY,
FirstName varchar,
LastName varchar,
BirthDate date,
Status varchar,
LastUpdated timestamptz
);
CREATE TABLE Concerts(
VenueId bigint NOT NULL,
SingerId bigint NOT NULL,
ConcertDate date NOT NULL,
BeginTime timestamptz,
EndTime timestamptz,
PRIMARY KEY(VenueId, SingerId, ConcertDate)
) COLUMNAR POLICY disabled;
You can also use ALTER TABLE with the SET COLUMNAR POLICY clause to enable or
disable the columnar policy on a table. The following example shows how to
disable the policy in the Singers table:
ALTER TABLE Singers SET COLUMNAR POLICY disabled;
To remove the database-level columnar policy configuration, use RESET:
ALTER DATABASE Music RESET spanner.columnar_policy;
Enabling Spanner columnar engine increases the storage usage of the target database or table (depending on the enabling option used) by approximately 60%. The exact increase depends on the type of data and its compressibility properties. It's important to ensure that the Spanner instance has sufficient storage capacity to accommodate the increase in storage usage. For more information, see Database limits.
Columnar file format generation
Spanner generates the columnar file format at compaction time. Compaction is a background process that typically is spread out over multiple days, but it might happen sooner if the size of the database grows substantially. For more information, see Optimal columnar coverage.
If you create a new database without data and enable columnar engine, Spanner stores data in columnar format as you insert it and as compactions occur in the background.
Columnar data format isn't generated for backups.
When you enable Spanner columnar engine on an existing database that has data in it, Spanner provides a mechanism to manually trigger compactions. For more information, see Manually trigger a data compaction.
What's next
- Learn about columnar engine.
- Learn how to query columnar data.
- Learn how to monitor columnar engine.