
com.pulumi.aws.timestreamwrite.kotlin.TableArgs.kt Maven / Gradle / Ivy
@file:Suppress("NAME_SHADOWING", "DEPRECATION")
package com.pulumi.aws.timestreamwrite.kotlin
import com.pulumi.aws.timestreamwrite.TableArgs.builder
import com.pulumi.aws.timestreamwrite.kotlin.inputs.TableMagneticStoreWritePropertiesArgs
import com.pulumi.aws.timestreamwrite.kotlin.inputs.TableMagneticStoreWritePropertiesArgsBuilder
import com.pulumi.aws.timestreamwrite.kotlin.inputs.TableRetentionPropertiesArgs
import com.pulumi.aws.timestreamwrite.kotlin.inputs.TableRetentionPropertiesArgsBuilder
import com.pulumi.aws.timestreamwrite.kotlin.inputs.TableSchemaArgs
import com.pulumi.aws.timestreamwrite.kotlin.inputs.TableSchemaArgsBuilder
import com.pulumi.core.Output
import com.pulumi.core.Output.of
import com.pulumi.kotlin.ConvertibleToJava
import com.pulumi.kotlin.PulumiTagMarker
import com.pulumi.kotlin.applySuspend
import kotlin.Pair
import kotlin.String
import kotlin.Suppress
import kotlin.Unit
import kotlin.collections.Map
import kotlin.jvm.JvmName
/**
* Provides a Timestream table resource.
* ## Example Usage
* ### Basic usage
*
* ```typescript
* import * as pulumi from "@pulumi/pulumi";
* import * as aws from "@pulumi/aws";
* const example = new aws.timestreamwrite.Table("example", {
* databaseName: exampleAwsTimestreamwriteDatabase.databaseName,
* tableName: "example",
* });
* ```
* ```python
* import pulumi
* import pulumi_aws as aws
* example = aws.timestreamwrite.Table("example",
* database_name=example_aws_timestreamwrite_database["databaseName"],
* table_name="example")
* ```
* ```csharp
* using System.Collections.Generic;
* using System.Linq;
* using Pulumi;
* using Aws = Pulumi.Aws;
* return await Deployment.RunAsync(() =>
* {
* var example = new Aws.TimestreamWrite.Table("example", new()
* {
* DatabaseName = exampleAwsTimestreamwriteDatabase.DatabaseName,
* TableName = "example",
* });
* });
* ```
* ```go
* package main
* import (
* "github.com/pulumi/pulumi-aws/sdk/v6/go/aws/timestreamwrite"
* "github.com/pulumi/pulumi/sdk/v3/go/pulumi"
* )
* func main() {
* pulumi.Run(func(ctx *pulumi.Context) error {
* _, err := timestreamwrite.NewTable(ctx, "example", ×treamwrite.TableArgs{
* DatabaseName: pulumi.Any(exampleAwsTimestreamwriteDatabase.DatabaseName),
* TableName: pulumi.String("example"),
* })
* if err != nil {
* return err
* }
* return nil
* })
* }
* ```
* ```java
* package generated_program;
* import com.pulumi.Context;
* import com.pulumi.Pulumi;
* import com.pulumi.core.Output;
* import com.pulumi.aws.timestreamwrite.Table;
* import com.pulumi.aws.timestreamwrite.TableArgs;
* import java.util.List;
* import java.util.ArrayList;
* import java.util.Map;
* import java.io.File;
* import java.nio.file.Files;
* import java.nio.file.Paths;
* public class App {
* public static void main(String[] args) {
* Pulumi.run(App::stack);
* }
* public static void stack(Context ctx) {
* var example = new Table("example", TableArgs.builder()
* .databaseName(exampleAwsTimestreamwriteDatabase.databaseName())
* .tableName("example")
* .build());
* }
* }
* ```
* ```yaml
* resources:
* example:
* type: aws:timestreamwrite:Table
* properties:
* databaseName: ${exampleAwsTimestreamwriteDatabase.databaseName}
* tableName: example
* ```
*
* ### Full usage
*
* ```typescript
* import * as pulumi from "@pulumi/pulumi";
* import * as aws from "@pulumi/aws";
* const example = new aws.timestreamwrite.Table("example", {
* databaseName: exampleAwsTimestreamwriteDatabase.databaseName,
* tableName: "example",
* retentionProperties: {
* magneticStoreRetentionPeriodInDays: 30,
* memoryStoreRetentionPeriodInHours: 8,
* },
* tags: {
* Name: "example-timestream-table",
* },
* });
* ```
* ```python
* import pulumi
* import pulumi_aws as aws
* example = aws.timestreamwrite.Table("example",
* database_name=example_aws_timestreamwrite_database["databaseName"],
* table_name="example",
* retention_properties={
* "magnetic_store_retention_period_in_days": 30,
* "memory_store_retention_period_in_hours": 8,
* },
* tags={
* "Name": "example-timestream-table",
* })
* ```
* ```csharp
* using System.Collections.Generic;
* using System.Linq;
* using Pulumi;
* using Aws = Pulumi.Aws;
* return await Deployment.RunAsync(() =>
* {
* var example = new Aws.TimestreamWrite.Table("example", new()
* {
* DatabaseName = exampleAwsTimestreamwriteDatabase.DatabaseName,
* TableName = "example",
* RetentionProperties = new Aws.TimestreamWrite.Inputs.TableRetentionPropertiesArgs
* {
* MagneticStoreRetentionPeriodInDays = 30,
* MemoryStoreRetentionPeriodInHours = 8,
* },
* Tags =
* {
* { "Name", "example-timestream-table" },
* },
* });
* });
* ```
* ```go
* package main
* import (
* "github.com/pulumi/pulumi-aws/sdk/v6/go/aws/timestreamwrite"
* "github.com/pulumi/pulumi/sdk/v3/go/pulumi"
* )
* func main() {
* pulumi.Run(func(ctx *pulumi.Context) error {
* _, err := timestreamwrite.NewTable(ctx, "example", ×treamwrite.TableArgs{
* DatabaseName: pulumi.Any(exampleAwsTimestreamwriteDatabase.DatabaseName),
* TableName: pulumi.String("example"),
* RetentionProperties: ×treamwrite.TableRetentionPropertiesArgs{
* MagneticStoreRetentionPeriodInDays: pulumi.Int(30),
* MemoryStoreRetentionPeriodInHours: pulumi.Int(8),
* },
* Tags: pulumi.StringMap{
* "Name": pulumi.String("example-timestream-table"),
* },
* })
* if err != nil {
* return err
* }
* return nil
* })
* }
* ```
* ```java
* package generated_program;
* import com.pulumi.Context;
* import com.pulumi.Pulumi;
* import com.pulumi.core.Output;
* import com.pulumi.aws.timestreamwrite.Table;
* import com.pulumi.aws.timestreamwrite.TableArgs;
* import com.pulumi.aws.timestreamwrite.inputs.TableRetentionPropertiesArgs;
* import java.util.List;
* import java.util.ArrayList;
* import java.util.Map;
* import java.io.File;
* import java.nio.file.Files;
* import java.nio.file.Paths;
* public class App {
* public static void main(String[] args) {
* Pulumi.run(App::stack);
* }
* public static void stack(Context ctx) {
* var example = new Table("example", TableArgs.builder()
* .databaseName(exampleAwsTimestreamwriteDatabase.databaseName())
* .tableName("example")
* .retentionProperties(TableRetentionPropertiesArgs.builder()
* .magneticStoreRetentionPeriodInDays(30)
* .memoryStoreRetentionPeriodInHours(8)
* .build())
* .tags(Map.of("Name", "example-timestream-table"))
* .build());
* }
* }
* ```
* ```yaml
* resources:
* example:
* type: aws:timestreamwrite:Table
* properties:
* databaseName: ${exampleAwsTimestreamwriteDatabase.databaseName}
* tableName: example
* retentionProperties:
* magneticStoreRetentionPeriodInDays: 30
* memoryStoreRetentionPeriodInHours: 8
* tags:
* Name: example-timestream-table
* ```
*
* ### Customer-defined Partition Key
*
* ```typescript
* import * as pulumi from "@pulumi/pulumi";
* import * as aws from "@pulumi/aws";
* const example = new aws.timestreamwrite.Table("example", {
* databaseName: exampleAwsTimestreamwriteDatabase.databaseName,
* tableName: "example",
* schema: {
* compositePartitionKey: {
* enforcementInRecord: "REQUIRED",
* name: "attr1",
* type: "DIMENSION",
* },
* },
* });
* ```
* ```python
* import pulumi
* import pulumi_aws as aws
* example = aws.timestreamwrite.Table("example",
* database_name=example_aws_timestreamwrite_database["databaseName"],
* table_name="example",
* schema={
* "composite_partition_key": {
* "enforcement_in_record": "REQUIRED",
* "name": "attr1",
* "type": "DIMENSION",
* },
* })
* ```
* ```csharp
* using System.Collections.Generic;
* using System.Linq;
* using Pulumi;
* using Aws = Pulumi.Aws;
* return await Deployment.RunAsync(() =>
* {
* var example = new Aws.TimestreamWrite.Table("example", new()
* {
* DatabaseName = exampleAwsTimestreamwriteDatabase.DatabaseName,
* TableName = "example",
* Schema = new Aws.TimestreamWrite.Inputs.TableSchemaArgs
* {
* CompositePartitionKey = new Aws.TimestreamWrite.Inputs.TableSchemaCompositePartitionKeyArgs
* {
* EnforcementInRecord = "REQUIRED",
* Name = "attr1",
* Type = "DIMENSION",
* },
* },
* });
* });
* ```
* ```go
* package main
* import (
* "github.com/pulumi/pulumi-aws/sdk/v6/go/aws/timestreamwrite"
* "github.com/pulumi/pulumi/sdk/v3/go/pulumi"
* )
* func main() {
* pulumi.Run(func(ctx *pulumi.Context) error {
* _, err := timestreamwrite.NewTable(ctx, "example", ×treamwrite.TableArgs{
* DatabaseName: pulumi.Any(exampleAwsTimestreamwriteDatabase.DatabaseName),
* TableName: pulumi.String("example"),
* Schema: ×treamwrite.TableSchemaArgs{
* CompositePartitionKey: ×treamwrite.TableSchemaCompositePartitionKeyArgs{
* EnforcementInRecord: pulumi.String("REQUIRED"),
* Name: pulumi.String("attr1"),
* Type: pulumi.String("DIMENSION"),
* },
* },
* })
* if err != nil {
* return err
* }
* return nil
* })
* }
* ```
* ```java
* package generated_program;
* import com.pulumi.Context;
* import com.pulumi.Pulumi;
* import com.pulumi.core.Output;
* import com.pulumi.aws.timestreamwrite.Table;
* import com.pulumi.aws.timestreamwrite.TableArgs;
* import com.pulumi.aws.timestreamwrite.inputs.TableSchemaArgs;
* import com.pulumi.aws.timestreamwrite.inputs.TableSchemaCompositePartitionKeyArgs;
* import java.util.List;
* import java.util.ArrayList;
* import java.util.Map;
* import java.io.File;
* import java.nio.file.Files;
* import java.nio.file.Paths;
* public class App {
* public static void main(String[] args) {
* Pulumi.run(App::stack);
* }
* public static void stack(Context ctx) {
* var example = new Table("example", TableArgs.builder()
* .databaseName(exampleAwsTimestreamwriteDatabase.databaseName())
* .tableName("example")
* .schema(TableSchemaArgs.builder()
* .compositePartitionKey(TableSchemaCompositePartitionKeyArgs.builder()
* .enforcementInRecord("REQUIRED")
* .name("attr1")
* .type("DIMENSION")
* .build())
* .build())
* .build());
* }
* }
* ```
* ```yaml
* resources:
* example:
* type: aws:timestreamwrite:Table
* properties:
* databaseName: ${exampleAwsTimestreamwriteDatabase.databaseName}
* tableName: example
* schema:
* compositePartitionKey:
* enforcementInRecord: REQUIRED
* name: attr1
* type: DIMENSION
* ```
*
* ## Import
* Using `pulumi import`, import Timestream tables using the `table_name` and `database_name` separate by a colon (`:`). For example:
* ```sh
* $ pulumi import aws:timestreamwrite/table:Table example ExampleTable:ExampleDatabase
* ```
* @property databaseName The name of the Timestream database.
* @property magneticStoreWriteProperties Contains properties to set on the table when enabling magnetic store writes. See Magnetic Store Write Properties below for more details.
* @property retentionProperties The retention duration for the memory store and magnetic store. See Retention Properties below for more details. If not provided, `magnetic_store_retention_period_in_days` default to 73000 and `memory_store_retention_period_in_hours` defaults to 6.
* @property schema The schema of the table. See Schema below for more details.
* @property tableName The name of the Timestream table.
* @property tags Map of tags to assign to this resource. If configured with a provider `default_tags` configuration block present, tags with matching keys will overwrite those defined at the provider-level.
*/
public data class TableArgs(
public val databaseName: Output? = null,
public val magneticStoreWriteProperties: Output? = null,
public val retentionProperties: Output? = null,
public val schema: Output? = null,
public val tableName: Output? = null,
public val tags: Output
© 2015 - 2025 Weber Informatics LLC | Privacy Policy