步骤 8:使用 .NET 查询 DynamoDB 表 - Amazon DynamoDB
AWS 文档中描述的 AWS 服务或功能可能因区域而异。要查看适用于中国区域的差异,请参阅中国的 AWS 服务入门

本文属于机器翻译版本。若本译文内容与英语原文存在差异,则一律以英文原文为准。

步骤 8:使用 .NET 查询 DynamoDB 表

Microsoft .NET 和 DynamoDB 教程的本步骤中,您将以三种不同的方式查询 Movies 表。

使用简单的文档模型搜索来查询 1985 年的电影

要设置简单的文档模型查询,Main 中的 DynamoDB_intro 函数通过调用 Search API 创建一个 Table.Query 对象,使用 1985 作为分区键(也称为哈希键)并创建空筛选条件 Expression

try { search = moviesTable.Query( 1985, new Expression( ) ); }

它随后等待 SearchListing_async,后者在 08_Querying.cs 中实现以检索和显示查询结果。

using System; using System.Threading.Tasks; using Amazon.DynamoDBv2.Model; using Amazon.DynamoDBv2.DocumentModel; using System.Collections.Generic; namespace DynamoDB_intro { public static partial class DdbIntro { public static async Task<List<List<Document>>> SearchListing_async(Search search) { List<List<Document>> docsList = new List<List<Document>>(); do { try { var getNextBatch = search.GetNextSetAsync(); var docList = await getNextBatch; docsList.Add(docList); } catch (Exception) { return null; } } while (!search.IsDone); return docsList; } public static async Task<QueryResponse> ClientQuerying_async(QueryRequest qRequest) { var response = await Client.QueryAsync(qRequest); return response; } }

使用 QueryOperationConfig 创建更复杂的查询搜索

为了查询 1992 年的名称从“B...”到“Hzz...”的电影,Main 函数创建了一个包含 QueryFilter 和各种其他字段的 QueryOperationConfig 对象。

QueryOperationConfig config = new QueryOperationConfig( ); config.Filter = new QueryFilter( ); config.Filter.AddCondition( "year", QueryOperator.Equal, new DynamoDBEntry[ ] { 1992 } ); config.Filter.AddCondition( "title", QueryOperator.Between, new DynamoDBEntry[ ] { "B", "Hzz" } ); config.AttributesToGet = new List<string> { "year", "title", "info" }; config.Select = SelectValues.SpecificAttributes;

然后,它再次通过调用 Table.Query API 创建了一个 Search 对象,这一次将 QueryOperationConfig 对象作为唯一的参数。

然后,它将再次等待 SearchListing_async 检索和显示查询结果。

使用低级别查询查找 1992 年的名称在“M...”和“Tzz...”之间的电影

为了使用低级别查询检索 1992 年的名称从“M...”到“Tzz...”的电影,Main 函数创建了一个 QueryRequest 对象。

QueryRequest qRequest= new QueryRequest { TableName = "Movies", ExpressionAttributeNames = new Dictionary<string, string> { { "#yr", "year" } }, ExpressionAttributeValues = new Dictionary<string, AttributeValue> { { ":qYr", new AttributeValue { N = "1992" } }, { ":tSt", new AttributeValue { S = "M" } }, { ":tEn", new AttributeValue { S = "Tzz" } } }, KeyConditionExpression = "#yr = :qYr and title between :tSt and :tEn", ProjectionExpression = "#yr, title, info.actors[0], info.genres, info.running_time_secs" };

然后,它会等待在 ClientQuerying_async 文件中实现的 08_Querying.cs 函数。ClientQuerying_async 转而等待低级别 DynamoDB 方法 AmazonDynamoDBClient.QueryAsync 检索查询结果。

注意

由于“year”是 DynamoDB 中的保留字,您需要使用 ExpressionAttributeNames 为它创建一个别名(此处为 #yr)以在低级别表达式中使用它。

下一步

步骤 9:使用 .NET 扫描 Movies 表