Product Documentation

FairCom DB API API for C++

Previous Topic

Next Topic

Introduction to the FairCom DB API API for C++

The c-tree Database API for C++ is a record-oriented database API. Its short name is FairCom DB API for C++ or simply CTDB. It is in the "NAV" family of APIs because it makes it easy for application developers to navigate data — no matter how complex.

FairCom DB API for C++ is an object-oriented API that provides precise control over every aspect of data processing. It leverages the familiar concepts of databases, tables, records and fields. For example, it can connect to a database, open a table, find a record by key, and walk records in key order.

The FairCom DB API API makes it easy to navigate and process data very quickly across multiple databases no matter where they are located. Its unique ability is to simultaneously open cursors into multiple databases and remote control them. Applications use cursors to control every detail of record lookup and traversal. There are multiple types of cursors: index, table, filtered, range, metadata, batch query, batch insert, batch update, and batch delete. Each is optimized to make different use cases easy and fast. For example, your application can retrieve a record from one database and use its data to quickly position a cursor in another database to batch retrieve additional records.

Because the FairCom Database Engine is optimized specifically for cursors, applications can easily do very complex data processing tasks at high speed. Developers are not limited to using built-in SQL or GQL algorithms. A software developer can easily implement algorithms to traverse data as hierarchies, graphs, objects, tables, etc. A data engineer or data scientist can implement unique algorithms for machine learning, graph analytics, knowledge graphs, big data, etc. A back-end programmer can implement optimized algorithms for real-time transaction processing, high-velocity inserts, specialized microservices, etc.

While navigating records, a developer can do anything with the data, such as insert, update, and delete records. FairCom DB API can find, retrieve, and process field values. Field values can be any common data type: JSON, custom binary structures, arrays, strings, numbers of all types, dates, times, monetary values, Boolean, etc. The database can automatically index fields containing these data types.

FairCom DB API works simultaneously with SQL. Applications can use SQL and FairCom DB API at the same time on the same data. SQL tools can simultaneously work with the same data as an application using FairCom DB API.

SQL is ideal for writing queries that join data. FairCom DB API is ideal for navigating complex data, such as walking hierarchies and graphs or implementing custom data processing algorithms. FairCom DB API is easier than SQL because there is very little to learn and it is 100% predictable.

FairCom DB API makes it easy to process complex data because developers can leverage the full power of their development language to break down complexity into manageable code. FairCom DB API extends a developer's favorite development language directly into the database. In other words, a programmer can use their favorite programming language to remote control the database and directly process data. FairCom DB API eliminates the need to learn a proprietary database language; instead, a developer’s favorite language becomes the database language.

FairCom DB API is ideal for achieving extreme, predictable performance because it gives developers complete control over:

  • Navigating records in any order
    • Index- or table-order
    • Forward or backward
    • Filtered
    • Ranged
    • Partial-key
    • Bulk processed
    • Etc.
  • Saving record positions
  • Jumping back to saved positions
  • Controlling if and how each record is locked
  • Managing which records participate in transactions
  • Using custom algorithms to join data across tables
  • etc.

TOCIndex