DocumentDB-기록 제한

Microsoft는 최근 SQL 문법에 대한 TOP 키워드와 같이 Azure DocumentDB를 쿼리 할 수있는 방법에 대한 여러 개선 사항을 추가하여 쿼리를 더 빠르게 실행하고 리소스를 더 적게 사용하며 쿼리 연산자에 대한 제한을 늘리고 LINQ 연산자에 대한 추가 지원을 추가했습니다. .NET SDK.

처음 두 레코드 만 검색하는 간단한 예를 살펴 보겠습니다. 여러 레코드가 있고 일부만 검색하려는 경우 Top 키워드를 사용할 수 있습니다. 이 예에서 우리는 지진에 대한 많은 기록을 가지고 있습니다.

이제 처음 두 레코드 만 표시하려고합니다.

Step 1 − 쿼리 탐색기로 이동하여이 쿼리를 실행합니다.

SELECT * FROM c 
WHERE c.magnitude > 2.5

아직 TOP 키워드를 지정하지 않았기 때문에 4 개의 레코드를 검색 한 것을 볼 수 있습니다.

Step 2− 이제 동일한 쿼리에 TOP 키워드를 사용합니다. 여기에서 TOP 키워드를 지정했으며 '2'는 두 개의 레코드 만 필요함을 의미합니다.

SELECT TOP 2 * FROM c 
WHERE c.magnitude > 2.5

Step 3 − 이제이 쿼리를 실행하면 두 개의 레코드 만 검색되는 것을 볼 수 있습니다.

마찬가지로 .Net SDK를 사용하여 코드에서 TOP 키워드를 사용할 수 있습니다. 다음은 구현입니다.

private async static Task QueryDocumentsWithPaging(DocumentClient client) {
   Console.WriteLine(); 
   Console.WriteLine("**** Query Documents (paged results) ****"); 
   Console.WriteLine();  
   Console.WriteLine("Quering for all documents"); 
	
   var sql = "SELECT TOP 3 * FROM c";  
   var query = client 
      .CreateDocumentQuery(collection.SelfLink, sql) 
      .AsDocumentQuery(); 
		
   while (query.HasMoreResults) {
      var documents = await query.ExecuteNextAsync(); 
		
      foreach (var document in documents) { 
         Console.WriteLine(" PublicId: {0}; Magnitude: {1};", document.publicid,
            document.magnitude); 
      } 
   } 
	
   Console.WriteLine(); 
}

다음은 DocumentClient 및 지진 데이터베이스를 인스턴스화하는 CreateDocumentClient 작업입니다.

private static async Task CreateDocumentClient() {
   // Create a new instance of the DocumentClient 
   using (var client = new DocumentClient(new Uri(EndpointUrl), AuthorizationKey)) {
      database = client.CreateDatabaseQuery("SELECT * FROM c WHERE c.id =
         'earthquake'").AsEnumerable().First(); 
			
      collection = client.CreateDocumentCollectionQuery(database.CollectionsLink,
         "SELECT * FROM c WHERE c.id = 'earthquakedata'").AsEnumerable().First(); 
			
      await QueryDocumentsWithPaging(client); 
   } 
}

위의 코드가 컴파일되고 실행되면 세 개의 레코드 만 검색되는 것을 볼 수 있습니다.

**** Query Documents (paged results) **** 
 
Quering for all documents 
PublicId: 2015p947400; Magnitude: 2.515176918; 
PublicId: 2015p947373; Magnitude: 1.506774108; 
PublicId: 2015p947329; Magnitude: 1.593394461;