/* * Copyright 2010-2014 Amazon.com, Inc. or its affiliates. All Rights Reserved. * * Licensed under the Apache License, Version 2.0 (the "License"). * You may not use this file except in compliance with the License. * A copy of the License is located at * * http://aws.amazon.com/apache2.0 * * or in the "license" file accompanying this file. This file is distributed * on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either * express or implied. See the License for the specific language governing * permissions and limitations under the License. */ /* * Do not modify this file. This file is generated from the dynamodb-2012-08-10.normal.json service model. */ using System; using System.Collections.Generic; using System.Xml.Serialization; using System.Text; using System.IO; using Amazon.Runtime; using Amazon.Runtime.Internal; namespace Amazon.DynamoDBv2.Model { /// /// Represents the properties of a local secondary index. /// public partial class LocalSecondaryIndex { private string _indexName; private List _keySchema = new List(); private Projection _projection; /// /// Gets and sets the property IndexName. /// /// The name of the local secondary index. The name must be unique among all other indexes /// on this table. /// /// [AWSProperty(Required=true, Min=3, Max=255)] public string IndexName { get { return this._indexName; } set { this._indexName = value; } } // Check to see if IndexName property is set internal bool IsSetIndexName() { return this._indexName != null; } /// /// Gets and sets the property KeySchema. /// /// The complete key schema for the local secondary index, consisting of one or more pairs /// of attribute names and key types: /// ///
  • /// /// HASH - partition key /// ///
  • /// /// RANGE - sort key /// ///
/// /// The partition key of an item is also known as its hash attribute. The term /// "hash attribute" derives from DynamoDB's usage of an internal hash function to evenly /// distribute data items across partitions, based on their partition key values. /// /// /// /// The sort key of an item is also known as its range attribute. The term "range /// attribute" derives from the way DynamoDB stores items with the same partition key /// physically close together, in sorted order by the sort key value. /// /// ///
[AWSProperty(Required=true, Min=1, Max=2)] public List KeySchema { get { return this._keySchema; } set { this._keySchema = value; } } // Check to see if KeySchema property is set internal bool IsSetKeySchema() { return this._keySchema != null && this._keySchema.Count > 0; } /// /// Gets and sets the property Projection. /// /// Represents attributes that are copied (projected) from the table into the local secondary /// index. These are in addition to the primary key attributes and index key attributes, /// which are automatically projected. /// /// [AWSProperty(Required=true)] public Projection Projection { get { return this._projection; } set { this._projection = value; } } // Check to see if Projection property is set internal bool IsSetProjection() { return this._projection != null; } } }