Nota
El acceso a esta página requiere autorización. Puede intentar iniciar sesión o cambiar directorios.
El acceso a esta página requiere autorización. Puede intentar cambiar los directorios.
En este inicio rápido, implementará una aplicación básica de Azure Cosmos DB for Table mediante Azure SDK para Java. Azure Cosmos DB for Table es un almacén de datos sin esquema que permite a las aplicaciones almacenar datos de tabla estructurados en la nube. Aprenderá a crear tablas y filas, y a realizar tareas básicas en el recurso de Azure Cosmos DB mediante el SDK de Azure para Java.
Documentación de referencia de la API | Código fuente de la biblioteca | Paquete (Maven) | Azure Developer CLI
Requisitos previos
- Azure Developer CLI
- Docker Desktop
- Java 21
Antes de comenzar, si no tiene una cuenta de Azure, cree una gratuita.
Inicialización del proyecto
Use Azure Developer CLI (azd) para crear una cuenta de Azure Cosmos DB for Table e implementar una aplicación de ejemplo contenedorizada. La aplicación de ejemplo usa la biblioteca cliente para administrar, crear, leer y consultar datos de ejemplo.
Abra un terminal en un directorio vacío.
Si aún no está autenticado, autentíquese en Azure Developer CLI mediante
azd auth login. Siga los pasos especificados por la herramienta para autenticarse en la CLI mediante sus credenciales de Azure preferidas.azd auth loginEjecute
azd initpara inicializar el proyecto.azd init --template cosmos-db-table-java-quickstartDurante la inicialización, configure un nombre de entorno único.
Implemente la cuenta de Azure Cosmos DB mediante
azd up. Las plantillas de Bicep también implementan una aplicación web de muestra.azd upDurante el proceso de aprovisionamiento, seleccione la suscripción, la ubicación deseada y el grupo de recursos de destino. Espere a que se complete el proceso de aprovisionamiento. El proceso puede tardar aproximadamente cinco minutos.
Una vez realizado el aprovisionamiento de los recursos de Azure, se incluye una dirección URL a la aplicación web en ejecución en la salida.
Deploying services (azd deploy) (✓) Done: Deploying service web - Endpoint: <https://[container-app-sub-domain].azurecontainerapps.io> SUCCESS: Your application was provisioned and deployed to Azure in 5 minutes 0 seconds.Use la dirección URL de la consola para ir a la aplicación web en el explorador. Observe la salida de la aplicación en ejecución.
Instalación de la biblioteca cliente
La biblioteca cliente está disponible a través de Maven, como paquete azure-data-tables.
Vaya a la carpeta
/src/weby abra el archivo pom.xml.cd ./srcSi aún no existe, agregue una entrada para el paquete
azure-data-tables.<dependency> <groupId>com.azure</groupId> <artifactId>azure-data-tables</artifactId> </dependency>
Importar bibliotecas
Importe todos los espacios de nombres necesarios en el código de la aplicación.
import com.azure.core.http.rest.PagedFlux;
import com.azure.data.tables.TableAsyncClient;
import com.azure.data.tables.TableClientBuilder;
import com.azure.data.tables.models.ListEntitiesOptions;
import com.azure.data.tables.models.TableEntity;
import com.azure.identity.DefaultAzureCredential;
import com.azure.identity.DefaultAzureCredentialBuilder;
Modelo de objetos
| Nombre | Descripción |
|---|---|
TableServiceAsyncClient |
Este tipo es el tipo de cliente principal y se usa para administrar bases de datos o metadatos para toda la cuenta. |
TableAsyncClient |
Este tipo representa el cliente de una tabla dentro de la cuenta. |
Ejemplos de código
- Autenticar el cliente
- Obtención de una tabla
- Creación de una entidad
- Obtención de una entidad
- Consulta de entidades
En el código de ejemplo de la plantilla se usa una tabla denominada cosmicworks-products. La tabla cosmicworks-products contiene detalles como el nombre, la categoría, la cantidad, el precio, un identificador único y una marca de venta para cada producto. El contenedor usa un identificador único* como clave de fila y una categoría como clave de partición.
Autenticar el cliente
En este ejemplo se crea una nueva instancia de la clase TableServiceAsyncClient.
DefaultAzureCredential azureTokenCredential = new DefaultAzureCredentialBuilder()
.build();
TableServiceAsyncClient client = new TableServiceClientBuilder()
.endpoint("<azure-cosmos-db-table-account-endpoint>")
.credential(credential)
.buildAsyncClient();
Obtención de una tabla
En este ejemplo se crea una instancia de la clase TableAsyncClient mediante el método GetTableClient de la clase TableServiceClient.
TableAsyncClient table = client
.getTableClient("<azure-cosmos-db-table-name>");
Crear una entidad
La manera más fácil de crear una nueva entidad en una tabla es usar createEntity.
String rowKey = "aaaaaaaa-0000-1111-2222-bbbbbbbbbbbb";
String partitionKey = "gear-surf-surfboards";
TableEntity entity = new TableEntity(partitionKey, rowKey)
.addProperty("Name", "Yamba Surfboard")
.addProperty("Quantity", 12)
.addProperty("Price", 850.00)
.addProperty("Sale", false);
Cree una entidad en la colección mediante upsertEntity.
Mono<Void> response = table.upsertEntity(entity);
Obtención de una entidad
Puede recuperar una entidad específica de una tabla mediante getEntity.
String rowKey = "aaaaaaaa-0000-1111-2222-bbbbbbbbbbbb";
String partitionKey = "gear-surf-surfboards";
TableEntity entity = table.getEntity(partitionKey, rowKey);
Consulta de entidades
Después de insertar una entidad, también puede ejecutar una consulta para obtener todas las entidades que coinciden con un filtro específico mediante listEntities y la ListEntitiesOptions clase. Use el setFilter método para especificar un filtro OData de cadena.
ListEntitiesOptions options = new ListEntitiesOptions()
.setFilter("PartitionKey eq 'gear-surf-surfboards'");
PagedFlux<TableEntity> tableEntities = table.listEntities(options, null, null);
Analice los resultados paginados de la consulta mediante una suscripción.
tableEntities
.DoOnNext(entity -> {
// Do something
});
Limpieza de recursos
Cuando ya no necesite la aplicación o los recursos de ejemplo, quite la implementación correspondiente y todos los recursos.
azd down