DocumentDB - Создать базу данных

В этой главе мы узнаем, как создать базу данных. Чтобы использовать Microsoft Azure DocumentDB, у вас должна быть учетная запись DocumentDB, база данных, коллекция и документы. У нас уже есть учетная запись DocumentDB, теперь для создания базы данных у нас есть два варианта:

  • Портал Microsoft Azure или
  • .Net SDK

Создание базы данных для DocumentDB с помощью портала Microsoft Azure.

Чтобы создать базу данных с помощью портала, выполните следующие действия.

Step 1 - Войдите на портал Azure, и вы увидите панель управления.

Step 2 - Теперь щелкните созданную учетную запись DocumentDB, и вы увидите детали, как показано на следующем снимке экрана.

Step 3 - Выберите опцию «Добавить базу данных» и укажите идентификатор своей базы данных.

Step 4 - Щелкните ОК.

Вы видите, что база данных добавлена. На данный момент у него нет коллекции, но мы можем добавить коллекции позже, которые являются контейнерами, в которых будут храниться наши документы JSON. Обратите внимание, что у него есть как идентификатор, так и идентификатор ресурса.

Создание базы данных для DocumentDB с помощью .Net SDK

Чтобы создать базу данных с помощью .Net SDK, выполните следующие действия.

Step 1 - Откройте консольное приложение в Visual Studio из предыдущей главы.

Step 2- Создайте новую базу данных, создав новый объект базы данных. Чтобы создать новую базу данных, нам нужно только назначить свойство Id, которое мы устанавливаем на «mynewdb» в задаче CreateDatabase.

private async static Task CreateDatabase(DocumentClient client) {
   Console.WriteLine(); 
   Console.WriteLine("******** Create Database *******");
	
   var databaseDefinition = new Database { Id = "mynewdb" }; 
   var result = await client.CreateDatabaseAsync(databaseDefinition); 
   var database = result.Resource;
	
   Console.WriteLine(" Database Id: {0}; Rid: {1}", database.Id, database.ResourceId); 
   Console.WriteLine("******** Database Created *******"); 
}

Step 3- Теперь передайте это определение базы данных в CreateDatabaseAsync и получите результат со свойством Resource. Все методы создания объекта возвращают свойство Resource, которое описывает созданный элемент, которым в данном случае является база данных.

Мы получаем новый объект базы данных из свойства Resource, и он отображается в консоли вместе с идентификатором ресурса, который ему присвоил DocumentDB.

Step 4 - Теперь вызовите задачу CreateDatabase из задачи CreateDocumentClient после создания экземпляра DocumentClient.

using (var client = new DocumentClient(new Uri(EndpointUrl), AuthorizationKey)) { 
   await CreateDatabase(client); 
}

Ниже приведен полный файл Program.cs на данный момент.

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

using Microsoft.Azure.Documents;
using Microsoft.Azure.Documents.Client;
using Microsoft.Azure.Documents.Linq;
using Newtonsoft.Json;

namespace DocumentDBDemo {

   class Program {
      private const string EndpointUrl = "https://azuredocdbdemo.documents.azure.com:443/";
		
      private const string AuthorizationKey = "BBhjI0gxdVPdDbS4diTjdloJq7Fp4L5RO/
         StTt6UtEufDM78qM2CtBZWbyVwFPSJIm8AcfDu2O+AfV T+TYUnBQ==";
			
      static void Main(string[] args) {
         try {
            CreateDocumentClient().Wait();
         } catch (Exception e) {
            Exception baseException = e.GetBaseException();
            Console.WriteLine("Error: {0}, Message: {1}", e.Message, baseException.Message);
         }
         Console.ReadKey();
      }
		
      private static async Task CreateDocumentClient() {
         // Create a new instance of the DocumentClient
         using (var client = new DocumentClient(new Uri(EndpointUrl), AuthorizationKey)) {
            await CreateDatabase(client);
         } 
      }
		
      private async static Task CreateDatabase(DocumentClient client) {
         Console.WriteLine();
         Console.WriteLine("******** Create Database *******");
			
         var databaseDefinition = new Database { Id = "mynewdb" };
         var result = await client.CreateDatabaseAsync(databaseDefinition);
         var database = result.Resource;
			
         Console.WriteLine(" Database Id: {0}; Rid: {1}", database.Id, database.ResourceId);
         Console.WriteLine("******** Database Created *******");
      }
		
   } 
}

Когда приведенный выше код скомпилирован и выполнен, вы получите следующий вывод, который содержит идентификаторы базы данных и ресурсов.

******** Create Database ******* 
 Database Id: mynewdb; Rid: ltpJAA== 
******** Database Created *******