Azure Cosmos DB is a globally-distributed database service that allows developers to work with data using a variety of standard APIs, such as SQL, MongoDB, Graph, and Azure Table storage.
- Spring Data CRUDRepository basic CRUD functionality
- save
- findAll
- findOne by Id
- deleteAll
- delete by Id
- delete entity
- Spring Data @Id annotation.
There're 2 ways to map a field in domain class to
id
of Azure Cosmos DB document.- annotate a field in domain class with @Id, this field will be mapped to document
id
in Cosmos DB. - set name of this field to
id
, this field will be mapped to documentid
in Cosmos DB. [Note] if both way applied,
- annotate a field in domain class with @Id, this field will be mapped to document
- Custom collection Name.
By default, collection name will be class name of user domain class. To customize it, add annotation
@Document(collection="myCustomCollectionName")
to your domain class, that's all. - Supports Azure Cosmos DB partition. To specify a field of your domain class to be partition key field, just annotate it with
@PartitionKey
. When you do CRUD operation, please specify your partition value. For more sample on partition CRUD, please refer to test here - Supports Spring Data custom query find operation.
- Supports spring-boot-starter-data-rest.
- Supports List and nested type in domain class.
Please refer to sample project here.
azure-cosmosdb-spring-boot-starter
is published on Maven Central Repository.
If you are using Maven, add the following dependency.
<dependency>
<groupId>com.microsoft.azure</groupId>
<artifactId>azure-cosmosdb-spring-boot-starter</artifactId>
<version>2.1.6</version>
</dependency>
Open application.properties
file and add below properties with your Cosmos DB credentials.
azure.cosmosdb.uri=your-documentdb-uri
azure.cosmosdb.key=your-documentdb-key
azure.cosmosdb.database=your-documentdb-databasename
Property azure.cosmosdb.consistency-level
is also supported.
Define a simple entity as Document in Cosmos DB.
@Document(collection = "mycollection")
public class User {
private String id;
private String firstName;
private String lastName;
// if emailAddress is mapped to id, then
// @Id
// private String emailAddress
... // setters and getters
public User(String id, String firstName, String lastName) {
this.id = id;
this.firstName = firstName;
this.lastName = lastName;
}
@Override
public String toString() {
return String.format("User: %s %s, %s", firstName, lastName);
}
}
id
field will be used as document id
in Azure Cosmos DB. Or you can annotate any field with @Id
to map it to document id
.
Annotation @Document(collection="mycollection")
is used to specify the collection name of your document in Azure Cosmos DB.
Extends DocumentDbRepository interface, which provides Spring Data repository support.
import com.microsoft.azure.spring.data.cosmosdb.repository.DocumentDbRepository;
import org.springframework.stereotype.Repository;
@Repository
public interface UserRepository extends DocumentDbRepository<User, String> {
}
So far DocumentDbRepository provides basic save, delete and find operations. More operations will be supported later.
Here create an application class with all the components
@SpringBootApplication
public class SampleApplication implements CommandLineRunner {
@Autowired
private UserRepository repository;
public static void main(String[] args) {
SpringApplication.run(SampleApplication.class, args);
}
public void run(String... var1) throws Exception {
final User testUser = new User("testId", "testFirstName", "testLastName");
repository.deleteAll();
repository.save(testUser);
final User result = repository.findOne(testUser.getId());
// if emailAddress is mapped to id, then
// final User result = respository.findOne(testUser.getEmailAddress());
}
}
Autowired UserRepository interface, then can do save, delete and find operations.
Microsoft would like to collect data about how users use this Spring boot starter. Microsoft uses this information to improve our tooling experience. Participation is voluntary. If you don't want to participate, just simply disable it by setting below configuration in application.properties
.
azure.cosmosdb.allow-telemetry=false
Find more information about Azure Service Privacy Statement, please check Microsoft Online Services Privacy Statement.
Besides using this Azure DocumentDB Spring Boot Starter, you can directly use Spring Data for Azure DocumentDB package for more complex scenarios. Please refer to Spring Data for Azure DocumentDB for more details.