"If a worker wants to do his job well, he must first sharpen his tools." - Confucius, "The Analects of Confucius. Lu Linggong"
Front page > Programming > Announcing General Availability of the C++ SDK for Couchbase

Announcing General Availability of the C++ SDK for Couchbase

Published on 2024-08-06
Browse:263

Announcing General Availability of the C   SDK for Couchbase

We are thrilled to announce the General Availability (GA) of the C SDKfor Couchbase! This release adds support for native C language to our existing comprehensive set of SDK libraries in 11 programming languages and marks a significant milestone in our commitment to providing robust, high-performance tools for developers to build modern, scalable applications. In fact, this C SDK is the core library behind our existing Python, NodeJS, Ruby, and PHP SDKs and strives to provide a consistent, performant and efficient experience across all these programming languages.

Why C SDK?

C remains a vital language for many developers due to its performance, efficiency, and control over system resources. By introducing the C SDK, Couchbase empowers developers to leverage these advantages while taking full benefit of Couchbase’s advanced NoSQL capabilities. Here are some key reasons why this release is a game-changer:

Performance

C is renowned for its speed and low-level memory management, making it ideal for applications where performance is critical. The C SDK for Couchbase ensures that you can build high-performance applications without sacrificing speed or efficiency.

Seamless Integration

The C SDK provides seamless integration with Couchbase Server, enabling developers to easily perform operations such as KV operations, SQL queries, and transactions. This tight integration ensures that your applications can scale effectively while maintaining high performance.

Modern API Design

The C SDK features a modern, idiomatic API that aligns with the latest C standards. This makes it not only powerful but also intuitive for C developers, reducing the learning curve and allowing you to start building applications quickly.

Key Features

Here are some of the standout features of the C SDK for Couchbase:

Easy Connection Management

The C SDK simplifies connection management, allowing you to establish and manage connections to your Couchbase cluster with minimal effort. This includes handling connection pooling, load balancing, and failover, ensuring your application remains resilient and performant. This means that the SDK can automatically read the topology of your cluster and provide seamless connections during topology changes such as cluster resizes or cluster upgrades. Below is an example of C code to connect to your couchbase database.

// Attempt to connect to the Couchbase cluster
auto [connect_err, cluster] = couchbase::cluster::connect(config.connection_string, options).get();

if (connect_err) {
    // Output the error message if connection fails
    std::cout 



Key-Value (KV) Operation Support

The C SDK natively supports performing key value operations. Key-value operations are unique to couchbase and provide very fast CRUD operations for documents stored in couchbase. Below is an example of C code to run a simple KV get & upsert of a document.

auto collection = cluster.bucket(config.bucket_name)
                         .scope(config.scope_name)
                         .collection(config.collection_name);

// KV- get
auto record = collection.get(document_id);
std::cout 



Rich Query, Search and Vector Search Support

The C SDK supports SQL queries, full-text search (FTS), and vector search, providing you with powerful tools to perform complex data operations. Whether you need to run sophisticated queries or perform full-text searches, the SDK has you covered.

Query Search

Below is a code snippet to execute a simple SQL query to fetch records from airlines collection:

auto scope = cluster.bucket(config.bucket_name).scope(config.scope_name);
  auto [err, resp] = scope.query("SELECT * FROM airline LIMIT 10").get();
  std::cout 



Full Text Search (FTS)

Below is a code snippet to execute a FTS query to do a full text search for “nice restaurants” the index created on the landmark collection:

auto scope = cluster.bucket(config.bucket_name).scope(config.scope_name);
auto [err, resp] = scope
  .search("travel-inventory-landmarks",
     couchbase::search_request(couchbase::query_string_query("nice restaurants")),
     couchbase::search_options{}.fields({ "content" }))
  .get();
for (const auto& row : resp.rows()) {
  auto fields = row.fields_as<:codec::tao_json_serializer>();
  std::cout 



Vector Search

Below is a code snippet to execute a vector search query:

auto scope = cluster.bucket(config.bucket_name).scope(config.scope_name);

// weights could be retrieved from your llm model or openAI
std::vector weights{ 0.1, 0.2, 0.3, 0.4 };
auto [err, resp] = scope
  .search("travel-inventory-landmarks",
    couchbase::search_request(couchbase::vector_search(
    couchbase::vector_query(field_name, weights))))
  .get();

for (const auto& row : resp.rows()) {
  auto fields = row.fields_as<:codec::tao_json_serializer>();
  std::cout 



Asynchronous Programming

The SDK supports asynchronous programming models, enabling you to build responsive, non-blocking applications. This is particularly useful for high-throughput applications where maintaining responsiveness is essential. Here’s an example of running a transaction in a asynchronous context:

std::shared_ptr ctx) -> couchbase::error {
  ctx->get(
    collection,
    some_id,
    // do something in this transaction
}

Transactions

This new C SDK includes support for transactions and replaces our existing C transaction support by adding more performance improvements and features. Below is a sample code snippet for create a transaction context:

std::shared_ptr<:transactions::attempt_context> ctx) -> couchbase::error {
  ctx.insert(collection, "doc-a", nlohmann::json({}));
  couchbase::transactions::transaction_get_result doc_a = ctx->get( collection, “doc-a”)
}

Robust Error Handling

Error handling is crucial in any application, and the C SDK, just like our other SDKs, provides comprehensive error handling capabilities including retry for connection drops, connection pooling and informative error messages. This ensures that you can gracefully handle and recover from errors, enhancing the stability and reliability of your applications.

Getting Started

To help you get started with the C SDK for Couchbase, we’ve prepared a detailed getting started guide on our documentation website. Here’s a quick overview of how to begin:

    • Install the SDK : Follow the installation instructions in the documentation to set up the SDK in your development environment.
    • Connect to Your Cluster : Connect to your Couchbase cluster.
    • Perform CRUD operations, run queries, and leveraging Couchbase’s powerful features.

Community and Support

We believe in the power of community and open-source development. The C SDK for Couchbase is open-source, and we encourage you to contribute, provide feedback, and join the conversation. For support, if you are our enterprise licensed customer, you can reach out via support, otherwise, you can access our comprehensive documentation, join the Couchbase Forums or Couchbase Discord, or reach out via our support portal.

Further Reading

To learn more, check out our documentation website. It goes into more detail on the API, especially around transactions and asynchronous operations and provides other reference material and sample bindings links for you to dig deeper:

    • Couchbase C SDK code examples
    • Couchbase C SDK documentation
    • Download and install Couchbase C SDK

Supported operating systems are listed on our documentation website.

Happy coding!

The Couchbase Team

The post Announcing General Availability of the C SDK for Couchbase appeared first on The Couchbase Blog.

Release Statement This article is reproduced at: https://dev.to/couchbase/announcing-general-availability-of-the-c-sdk-for-couchbase-51cg If there is any infringement, please contact [email protected] to delete it
Latest tutorial More>

Disclaimer: All resources provided are partly from the Internet. If there is any infringement of your copyright or other rights and interests, please explain the detailed reasons and provide proof of copyright or rights and interests and then send it to the email: [email protected] We will handle it for you as soon as possible.

Copyright© 2022 湘ICP备2022001581号-3