UNPKG

@aws-cdk/aws-redshift-alpha

Version:

The CDK Construct Library for AWS::Redshift

330 lines 39.4 kB
"use strict"; var _a; Object.defineProperty(exports, "__esModule", { value: true }); exports.ColumnEncoding = exports.TableSortStyle = exports.TableDistStyle = exports.Table = exports.TableAction = void 0; const jsiiDeprecationWarnings = require("../.warnings.jsii.js"); const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti"); /* eslint-disable import/no-extraneous-dependencies */ const cdk = require("aws-cdk-lib/core"); const cx_api_1 = require("aws-cdk-lib/cx-api"); const constructs_1 = require("constructs"); const database_query_1 = require("./private/database-query"); const handler_name_1 = require("./private/database-query-provider/handler-name"); const util_1 = require("./private/database-query-provider/util"); /** * An action that a Redshift user can be granted privilege to perform on a table. */ var TableAction; (function (TableAction) { /** * Grants privilege to select data from a table or view using a SELECT statement. */ TableAction[TableAction["SELECT"] = 0] = "SELECT"; /** * Grants privilege to load data into a table using an INSERT statement or a COPY statement. */ TableAction[TableAction["INSERT"] = 1] = "INSERT"; /** * Grants privilege to update a table column using an UPDATE statement. */ TableAction[TableAction["UPDATE"] = 2] = "UPDATE"; /** * Grants privilege to delete a data row from a table. */ TableAction[TableAction["DELETE"] = 3] = "DELETE"; /** * Grants privilege to drop a table. */ TableAction[TableAction["DROP"] = 4] = "DROP"; /** * Grants privilege to create a foreign key constraint. * * You need to grant this privilege on both the referenced table and the referencing table; otherwise, the user can't create the constraint. */ TableAction[TableAction["REFERENCES"] = 5] = "REFERENCES"; /** * Grants all available privileges at once to the specified user or user group. */ TableAction[TableAction["ALL"] = 6] = "ALL"; })(TableAction || (exports.TableAction = TableAction = {})); class TableBase extends constructs_1.Construct { grant(user, ...actions) { user.addTablePrivileges(this, ...actions); } } /** * A table in a Redshift cluster. */ class Table extends TableBase { /** * Specify a Redshift table using a table name and schema that already exists. */ static fromTableAttributes(scope, id, attrs) { try { jsiiDeprecationWarnings._aws_cdk_aws_redshift_alpha_TableAttributes(attrs); } catch (error) { if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { Error.captureStackTrace(error, this.fromTableAttributes); } throw error; } return new class extends TableBase { constructor() { super(...arguments); this.tableName = attrs.tableName; this.tableColumns = attrs.tableColumns; this.cluster = attrs.cluster; this.databaseName = attrs.databaseName; } }(scope, id); } constructor(scope, id, props) { super(scope, id); try { jsiiDeprecationWarnings._aws_cdk_aws_redshift_alpha_TableProps(props); } catch (error) { if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { Error.captureStackTrace(error, Table); } throw error; } this.validateDistKeyColumns(props.tableColumns); if (props.distStyle) { this.validateDistStyle(props.distStyle, props.tableColumns); } if (props.sortStyle) { this.validateSortStyle(props.sortStyle, props.tableColumns); } this.tableColumns = this.configureTableColumns(props.tableColumns); this.cluster = props.cluster; this.databaseName = props.databaseName; const useColumnIds = !!cdk.FeatureFlags.of(this).isEnabled(cx_api_1.REDSHIFT_COLUMN_ID); this.resource = new database_query_1.DatabaseQuery(this, 'Resource', { removalPolicy: cdk.RemovalPolicy.RETAIN, ...props, handler: handler_name_1.HandlerName.Table, properties: { tableName: { prefix: props.tableName ?? cdk.Names.uniqueId(this), generateSuffix: (props.tableName == null).toString(), }, tableColumns: this.tableColumns, distStyle: props.distStyle, sortStyle: props.sortStyle ?? this.getDefaultSortStyle(props.tableColumns), tableComment: props.tableComment, useColumnIds, }, }); this.tableName = props.tableName ?? this.resource.ref; } /** * Apply the given removal policy to this resource * * The Removal Policy controls what happens to this resource when it stops * being managed by CloudFormation, either because you've removed it from the * CDK application or because you've made a change that requires the resource * to be replaced. * * The resource can be destroyed (`RemovalPolicy.DESTROY`), or left in your AWS * account for data recovery and cleanup later (`RemovalPolicy.RETAIN`). * * This resource is retained by default. */ applyRemovalPolicy(policy) { this.resource.applyRemovalPolicy(policy); } validateDistKeyColumns(columns) { try { (0, util_1.getDistKeyColumn)(columns); } catch { throw new Error('Only one column can be configured as distKey.'); } } validateDistStyle(distStyle, columns) { const distKeyColumn = (0, util_1.getDistKeyColumn)(columns); if (distKeyColumn && distStyle !== TableDistStyle.KEY) { throw new Error(`Only 'TableDistStyle.KEY' can be configured when distKey is also configured. Found ${distStyle}`); } if (!distKeyColumn && distStyle === TableDistStyle.KEY) { throw new Error('distStyle of "TableDistStyle.KEY" can only be configured when distKey is also configured.'); } } validateSortStyle(sortStyle, columns) { const sortKeyColumns = (0, util_1.getSortKeyColumns)(columns); if (sortKeyColumns.length === 0 && sortStyle !== TableSortStyle.AUTO) { throw new Error(`sortStyle of '${sortStyle}' can only be configured when sortKey is also configured.`); } if (sortKeyColumns.length > 0 && sortStyle === TableSortStyle.AUTO) { throw new Error(`sortStyle of '${TableSortStyle.AUTO}' cannot be configured when sortKey is also configured.`); } } getDefaultSortStyle(columns) { const sortKeyColumns = (0, util_1.getSortKeyColumns)(columns); return (sortKeyColumns.length === 0) ? TableSortStyle.AUTO : TableSortStyle.COMPOUND; } configureTableColumns(columns) { const newColumns = [...columns]; const columnIds = new Set(); for (let i = 0; i < columns.length; i++) { const column = newColumns[i]; if (column.id) { if (columnIds.has(column.id)) { throw new Error(`Column id '${column.id}' is not unique.`); } columnIds.add(column.id); } else { if (columnIds.has(column.name)) { throw new Error(`Column name '${column.name}' is not unique amongst the column ids.`); } newColumns[i] = { ...column, id: column.name }; columnIds.add(column.name); } } return newColumns; } } exports.Table = Table; _a = JSII_RTTI_SYMBOL_1; Table[_a] = { fqn: "@aws-cdk/aws-redshift-alpha.Table", version: "2.211.0-alpha.0" }; /** * The data distribution style of a table. */ var TableDistStyle; (function (TableDistStyle) { /** * Amazon Redshift assigns an optimal distribution style based on the table data */ TableDistStyle["AUTO"] = "AUTO"; /** * The data in the table is spread evenly across the nodes in a cluster in a round-robin distribution. */ TableDistStyle["EVEN"] = "EVEN"; /** * The data is distributed by the values in the DISTKEY column. */ TableDistStyle["KEY"] = "KEY"; /** * A copy of the entire table is distributed to every node. */ TableDistStyle["ALL"] = "ALL"; })(TableDistStyle || (exports.TableDistStyle = TableDistStyle = {})); /** * The sort style of a table. */ var TableSortStyle; (function (TableSortStyle) { /** * Amazon Redshift assigns an optimal sort key based on the table data. */ TableSortStyle["AUTO"] = "AUTO"; /** * Specifies that the data is sorted using a compound key made up of all of the listed columns, * in the order they are listed. */ TableSortStyle["COMPOUND"] = "COMPOUND"; /** * Specifies that the data is sorted using an interleaved sort key. */ TableSortStyle["INTERLEAVED"] = "INTERLEAVED"; })(TableSortStyle || (exports.TableSortStyle = TableSortStyle = {})); /** * The compression encoding of a column. * * @see https://docs.aws.amazon.com/redshift/latest/dg/c_Compression_encodings.html */ var ColumnEncoding; (function (ColumnEncoding) { /** * Amazon Redshift assigns an optimal encoding based on the column data. * This is the default. */ ColumnEncoding["AUTO"] = "AUTO"; /** * The column is not compressed. * * @see https://docs.aws.amazon.com/redshift/latest/dg/c_Raw_encoding.html */ ColumnEncoding["RAW"] = "RAW"; /** * The column is compressed using the AZ64 algorithm. * * @see https://docs.aws.amazon.com/redshift/latest/dg/az64-encoding.html */ ColumnEncoding["AZ64"] = "AZ64"; /** * The column is compressed using a separate dictionary for each block column value on disk. * * @see https://docs.aws.amazon.com/redshift/latest/dg/c_Byte_dictionary_encoding.html */ ColumnEncoding["BYTEDICT"] = "BYTEDICT"; /** * The column is compressed based on the difference between values in the column. * This records differences as 1-byte values. * * @see https://docs.aws.amazon.com/redshift/latest/dg/c_Delta_encoding.html */ ColumnEncoding["DELTA"] = "DELTA"; /** * The column is compressed based on the difference between values in the column. * This records differences as 2-byte values. * * @see https://docs.aws.amazon.com/redshift/latest/dg/c_Delta_encoding.html */ ColumnEncoding["DELTA32K"] = "DELTA32K"; /** * The column is compressed using the LZO algorithm. * * @see https://docs.aws.amazon.com/redshift/latest/dg/lzo-encoding.html */ ColumnEncoding["LZO"] = "LZO"; /** * The column is compressed to a smaller storage size than the original data type. * The compressed storage size is 1 byte. * * @see https://docs.aws.amazon.com/redshift/latest/dg/c_MostlyN_encoding.html */ ColumnEncoding["MOSTLY8"] = "MOSTLY8"; /** * The column is compressed to a smaller storage size than the original data type. * The compressed storage size is 2 bytes. * * @see https://docs.aws.amazon.com/redshift/latest/dg/c_MostlyN_encoding.html */ ColumnEncoding["MOSTLY16"] = "MOSTLY16"; /** * The column is compressed to a smaller storage size than the original data type. * The compressed storage size is 4 bytes. * * @see https://docs.aws.amazon.com/redshift/latest/dg/c_MostlyN_encoding.html */ ColumnEncoding["MOSTLY32"] = "MOSTLY32"; /** * The column is compressed by recording the number of occurrences of each value in the column. * * @see https://docs.aws.amazon.com/redshift/latest/dg/c_Runlength_encoding.html */ ColumnEncoding["RUNLENGTH"] = "RUNLENGTH"; /** * The column is compressed by recording the first 245 unique words and then using a 1-byte index to represent each word. * * @see https://docs.aws.amazon.com/redshift/latest/dg/c_Text255_encoding.html */ ColumnEncoding["TEXT255"] = "TEXT255"; /** * The column is compressed by recording the first 32K unique words and then using a 2-byte index to represent each word. * * @see https://docs.aws.amazon.com/redshift/latest/dg/c_Text255_encoding.html */ ColumnEncoding["TEXT32K"] = "TEXT32K"; /** * The column is compressed using the ZSTD algorithm. * * @see https://docs.aws.amazon.com/redshift/latest/dg/zstd-encoding.html */ ColumnEncoding["ZSTD"] = "ZSTD"; })(ColumnEncoding || (exports.ColumnEncoding = ColumnEncoding = {})); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table.js","sourceRoot":"","sources":["table.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable import/no-extraneous-dependencies */\nimport * as cdk from 'aws-cdk-lib/core';\nimport { REDSHIFT_COLUMN_ID } from 'aws-cdk-lib/cx-api';\nimport { Construct, IConstruct } from 'constructs';\nimport { ICluster } from './cluster';\nimport { DatabaseOptions } from './database-options';\nimport { DatabaseQuery } from './private/database-query';\nimport { HandlerName } from './private/database-query-provider/handler-name';\nimport { getDistKeyColumn, getSortKeyColumns } from './private/database-query-provider/util';\nimport { TableHandlerProps } from './private/handler-props';\nimport { IUser } from './user';\n\n/**\n * An action that a Redshift user can be granted privilege to perform on a table.\n */\nexport enum TableAction {\n  /**\n   * Grants privilege to select data from a table or view using a SELECT statement.\n   */\n  SELECT,\n\n  /**\n   * Grants privilege to load data into a table using an INSERT statement or a COPY statement.\n   */\n  INSERT,\n\n  /**\n   * Grants privilege to update a table column using an UPDATE statement.\n   */\n  UPDATE,\n\n  /**\n   * Grants privilege to delete a data row from a table.\n   */\n  DELETE,\n\n  /**\n   * Grants privilege to drop a table.\n   */\n  DROP,\n\n  /**\n   * Grants privilege to create a foreign key constraint.\n   *\n   * You need to grant this privilege on both the referenced table and the referencing table; otherwise, the user can't create the constraint.\n   */\n  REFERENCES,\n\n  /**\n   * Grants all available privileges at once to the specified user or user group.\n   */\n  ALL,\n}\n\n/**\n * A column in a Redshift table.\n */\nexport interface Column {\n  /**\n   * The unique identifier of the column.\n   *\n   * This is not the name of the column, and renaming this identifier will cause a new column to be created and the old column to be dropped.\n   *\n   * **NOTE** - This field will be set, however, only by setting the `@aws-cdk/aws-redshift:columnId` feature flag will this field be used.\n   *\n   * @default - the column name is used as the identifier\n   */\n  readonly id?: string;\n\n  /**\n   * The name of the column. This will appear on Amazon Redshift.\n   */\n  readonly name: string;\n\n  /**\n   * The data type of the column.\n   */\n  readonly dataType: string;\n\n  /**\n   * Boolean value that indicates whether the column is to be configured as DISTKEY.\n   *\n   * @default - column is not DISTKEY\n   */\n  readonly distKey?: boolean;\n\n  /**\n   * Boolean value that indicates whether the column is to be configured as SORTKEY.\n   *\n   * @default - column is not a SORTKEY\n   */\n  readonly sortKey?: boolean;\n\n  /**\n   * The encoding to use for the column.\n   *\n   * @default - Amazon Redshift determines the encoding based on the data type.\n   */\n  readonly encoding?: ColumnEncoding;\n\n  /**\n   * A comment to attach to the column.\n   *\n   * @default - no comment\n   */\n  readonly comment?: string;\n}\n\n/**\n * Properties for configuring a Redshift table.\n */\nexport interface TableProps extends DatabaseOptions {\n  /**\n   * The name of the table.\n   *\n   * @default - a name is generated\n   */\n  readonly tableName?: string;\n\n  /**\n   * The columns of the table.\n   */\n  readonly tableColumns: Column[];\n\n  /**\n   * The distribution style of the table.\n   *\n   * @default TableDistStyle.AUTO\n   */\n  readonly distStyle?: TableDistStyle;\n\n  /**\n   * The sort style of the table.\n   *\n   * @default TableSortStyle.AUTO if no sort key is specified, TableSortStyle.COMPOUND if a sort key is specified\n   */\n  readonly sortStyle?: TableSortStyle;\n\n  /**\n   * The policy to apply when this resource is removed from the application.\n   *\n   * @default cdk.RemovalPolicy.Retain\n   */\n  readonly removalPolicy?: cdk.RemovalPolicy;\n\n  /**\n   * A comment to attach to the table.\n   *\n   * @default - no comment\n   */\n  readonly tableComment?: string;\n\n  /**\n   * Handler timeout duration.\n   *\n   * Valid values are between 1 second and 15 minutes.\n   *\n   * @default - 1 minute\n   */\n  readonly timeout?: cdk.Duration;\n}\n\n/**\n * Represents a table in a Redshift database.\n */\nexport interface ITable extends IConstruct {\n  /**\n   * Name of the table.\n   */\n  readonly tableName: string;\n\n  /**\n   * The columns of the table.\n   */\n  readonly tableColumns: Column[];\n\n  /**\n   * The cluster where the table is located.\n   */\n  readonly cluster: ICluster;\n\n  /**\n   * The name of the database where the table is located.\n   */\n  readonly databaseName: string;\n\n  /**\n   * Grant a user privilege to access this table.\n   */\n  grant(user: IUser, ...actions: TableAction[]): void;\n}\n\n/**\n * A full specification of a Redshift table that can be used to import it fluently into the CDK application.\n */\nexport interface TableAttributes {\n  /**\n   * Name of the table.\n   */\n  readonly tableName: string;\n\n  /**\n   * The columns of the table.\n   */\n  readonly tableColumns: Column[];\n\n  /**\n   * The cluster where the table is located.\n   */\n  readonly cluster: ICluster;\n\n  /**\n   * The name of the database where the table is located.\n   */\n  readonly databaseName: string;\n}\n\nabstract class TableBase extends Construct implements ITable {\n  abstract readonly tableName: string;\n  abstract readonly tableColumns: Column[];\n  abstract readonly cluster: ICluster;\n  abstract readonly databaseName: string;\n  grant(user: IUser, ...actions: TableAction[]) {\n    user.addTablePrivileges(this, ...actions);\n  }\n}\n\n/**\n * A table in a Redshift cluster.\n */\nexport class Table extends TableBase {\n  /**\n   * Specify a Redshift table using a table name and schema that already exists.\n   */\n  static fromTableAttributes(scope: Construct, id: string, attrs: TableAttributes): ITable {\n    return new class extends TableBase {\n      readonly tableName = attrs.tableName;\n      readonly tableColumns = attrs.tableColumns;\n      readonly cluster = attrs.cluster;\n      readonly databaseName = attrs.databaseName;\n    }(scope, id);\n  }\n\n  readonly tableName: string;\n  readonly tableColumns: Column[];\n  readonly cluster: ICluster;\n  readonly databaseName: string;\n\n  private resource: DatabaseQuery<TableHandlerProps>;\n\n  constructor(scope: Construct, id: string, props: TableProps) {\n    super(scope, id);\n\n    this.validateDistKeyColumns(props.tableColumns);\n    if (props.distStyle) {\n      this.validateDistStyle(props.distStyle, props.tableColumns);\n    }\n    if (props.sortStyle) {\n      this.validateSortStyle(props.sortStyle, props.tableColumns);\n    }\n\n    this.tableColumns = this.configureTableColumns(props.tableColumns);\n    this.cluster = props.cluster;\n    this.databaseName = props.databaseName;\n\n    const useColumnIds = !!cdk.FeatureFlags.of(this).isEnabled(REDSHIFT_COLUMN_ID);\n\n    this.resource = new DatabaseQuery<TableHandlerProps>(this, 'Resource', {\n      removalPolicy: cdk.RemovalPolicy.RETAIN,\n      ...props,\n      handler: HandlerName.Table,\n      properties: {\n        tableName: {\n          prefix: props.tableName ?? cdk.Names.uniqueId(this),\n          generateSuffix: (props.tableName == null).toString(),\n        },\n        tableColumns: this.tableColumns,\n        distStyle: props.distStyle,\n        sortStyle: props.sortStyle ?? this.getDefaultSortStyle(props.tableColumns),\n        tableComment: props.tableComment,\n        useColumnIds,\n      },\n    });\n\n    this.tableName = props.tableName ?? this.resource.ref;\n  }\n\n  /**\n   * Apply the given removal policy to this resource\n   *\n   * The Removal Policy controls what happens to this resource when it stops\n   * being managed by CloudFormation, either because you've removed it from the\n   * CDK application or because you've made a change that requires the resource\n   * to be replaced.\n   *\n   * The resource can be destroyed (`RemovalPolicy.DESTROY`), or left in your AWS\n   * account for data recovery and cleanup later (`RemovalPolicy.RETAIN`).\n   *\n   * This resource is retained by default.\n   */\n  public applyRemovalPolicy(policy: cdk.RemovalPolicy): void {\n    this.resource.applyRemovalPolicy(policy);\n  }\n\n  private validateDistKeyColumns(columns: Column[]): void {\n    try {\n      getDistKeyColumn(columns);\n    } catch {\n      throw new Error('Only one column can be configured as distKey.');\n    }\n  }\n\n  private validateDistStyle(distStyle: TableDistStyle, columns: Column[]): void {\n    const distKeyColumn = getDistKeyColumn(columns);\n    if (distKeyColumn && distStyle !== TableDistStyle.KEY) {\n      throw new Error(`Only 'TableDistStyle.KEY' can be configured when distKey is also configured. Found ${distStyle}`);\n    }\n    if (!distKeyColumn && distStyle === TableDistStyle.KEY) {\n      throw new Error('distStyle of \"TableDistStyle.KEY\" can only be configured when distKey is also configured.');\n    }\n  }\n\n  private validateSortStyle(sortStyle: TableSortStyle, columns: Column[]): void {\n    const sortKeyColumns = getSortKeyColumns(columns);\n    if (sortKeyColumns.length === 0 && sortStyle !== TableSortStyle.AUTO) {\n      throw new Error(`sortStyle of '${sortStyle}' can only be configured when sortKey is also configured.`);\n    }\n    if (sortKeyColumns.length > 0 && sortStyle === TableSortStyle.AUTO) {\n      throw new Error(`sortStyle of '${TableSortStyle.AUTO}' cannot be configured when sortKey is also configured.`);\n    }\n  }\n\n  private getDefaultSortStyle(columns: Column[]): TableSortStyle {\n    const sortKeyColumns = getSortKeyColumns(columns);\n    return (sortKeyColumns.length === 0) ? TableSortStyle.AUTO : TableSortStyle.COMPOUND;\n  }\n\n  private configureTableColumns(columns: Column[]): Column[] {\n    const newColumns = [...columns];\n    const columnIds = new Set<string>();\n    for (let i = 0; i < columns.length; i++) {\n      const column = newColumns[i];\n      if (column.id) {\n        if (columnIds.has(column.id)) {\n          throw new Error(`Column id '${column.id}' is not unique.`);\n        }\n        columnIds.add(column.id);\n      } else {\n        if (columnIds.has(column.name)) {\n          throw new Error(`Column name '${column.name}' is not unique amongst the column ids.`);\n        }\n        newColumns[i] = { ...column, id: column.name };\n        columnIds.add(column.name);\n      }\n    }\n    return newColumns;\n  }\n}\n\n/**\n * The data distribution style of a table.\n */\nexport enum TableDistStyle {\n  /**\n   *  Amazon Redshift assigns an optimal distribution style based on the table data\n   */\n  AUTO = 'AUTO',\n\n  /**\n   * The data in the table is spread evenly across the nodes in a cluster in a round-robin distribution.\n   */\n  EVEN = 'EVEN',\n\n  /**\n   * The data is distributed by the values in the DISTKEY column.\n   */\n  KEY = 'KEY',\n\n  /**\n   * A copy of the entire table is distributed to every node.\n   */\n  ALL = 'ALL',\n}\n\n/**\n * The sort style of a table.\n */\nexport enum TableSortStyle {\n  /**\n   * Amazon Redshift assigns an optimal sort key based on the table data.\n   */\n  AUTO = 'AUTO',\n\n  /**\n   * Specifies that the data is sorted using a compound key made up of all of the listed columns,\n   * in the order they are listed.\n   */\n  COMPOUND = 'COMPOUND',\n\n  /**\n   * Specifies that the data is sorted using an interleaved sort key.\n   */\n  INTERLEAVED = 'INTERLEAVED',\n}\n\n/**\n * The compression encoding of a column.\n *\n * @see https://docs.aws.amazon.com/redshift/latest/dg/c_Compression_encodings.html\n */\nexport enum ColumnEncoding {\n  /**\n   * Amazon Redshift assigns an optimal encoding based on the column data.\n   * This is the default.\n   */\n  AUTO = 'AUTO',\n\n  /**\n   * The column is not compressed.\n   *\n   * @see https://docs.aws.amazon.com/redshift/latest/dg/c_Raw_encoding.html\n   */\n  RAW = 'RAW',\n\n  /**\n   * The column is compressed using the AZ64 algorithm.\n   *\n   * @see https://docs.aws.amazon.com/redshift/latest/dg/az64-encoding.html\n   */\n  AZ64 = 'AZ64',\n\n  /**\n   * The column is compressed using a separate dictionary for each block column value on disk.\n   *\n   * @see https://docs.aws.amazon.com/redshift/latest/dg/c_Byte_dictionary_encoding.html\n   */\n  BYTEDICT = 'BYTEDICT',\n\n  /**\n   * The column is compressed based on the difference between values in the column.\n   * This records differences as 1-byte values.\n   *\n   * @see https://docs.aws.amazon.com/redshift/latest/dg/c_Delta_encoding.html\n   */\n  DELTA = 'DELTA',\n\n  /**\n   * The column is compressed based on the difference between values in the column.\n   * This records differences as 2-byte values.\n   *\n   * @see https://docs.aws.amazon.com/redshift/latest/dg/c_Delta_encoding.html\n   */\n  DELTA32K = 'DELTA32K',\n\n  /**\n   * The column is compressed using the LZO algorithm.\n   *\n   * @see https://docs.aws.amazon.com/redshift/latest/dg/lzo-encoding.html\n   */\n  LZO = 'LZO',\n\n  /**\n   * The column is compressed to a smaller storage size than the original data type.\n   * The compressed storage size is 1 byte.\n   *\n   * @see https://docs.aws.amazon.com/redshift/latest/dg/c_MostlyN_encoding.html\n   */\n  MOSTLY8 = 'MOSTLY8',\n\n  /**\n   * The column is compressed to a smaller storage size than the original data type.\n   * The compressed storage size is 2 bytes.\n   *\n   * @see https://docs.aws.amazon.com/redshift/latest/dg/c_MostlyN_encoding.html\n   */\n  MOSTLY16 = 'MOSTLY16',\n\n  /**\n   * The column is compressed to a smaller storage size than the original data type.\n   * The compressed storage size is 4 bytes.\n   *\n   * @see https://docs.aws.amazon.com/redshift/latest/dg/c_MostlyN_encoding.html\n   */\n  MOSTLY32 = 'MOSTLY32',\n\n  /**\n   * The column is compressed by recording the number of occurrences of each value in the column.\n   *\n   * @see https://docs.aws.amazon.com/redshift/latest/dg/c_Runlength_encoding.html\n   */\n  RUNLENGTH = 'RUNLENGTH',\n\n  /**\n   * The column is compressed by recording the first 245 unique words and then using a 1-byte index to represent each word.\n   *\n   * @see https://docs.aws.amazon.com/redshift/latest/dg/c_Text255_encoding.html\n   */\n  TEXT255 = 'TEXT255',\n\n  /**\n   * The column is compressed by recording the first 32K unique words and then using a 2-byte index to represent each word.\n   *\n   * @see https://docs.aws.amazon.com/redshift/latest/dg/c_Text255_encoding.html\n   */\n  TEXT32K = 'TEXT32K',\n\n  /**\n   * The column is compressed using the ZSTD algorithm.\n   *\n   * @see https://docs.aws.amazon.com/redshift/latest/dg/zstd-encoding.html\n   */\n  ZSTD = 'ZSTD',\n}\n"]}