Expand description

Native rust database driver for SAP HANA (TM).

hdbconnect provides a lean, fast, and easy-to-use rust-API for working with SAP HANA. The driver is written completely in rust. It interoperates elegantly with all data types that implement the standard serde::Serialize and/or serde::Deserialize traits, for input and output respectively. So, instead of iterating over a resultset by rows and columns, you can assign the complete resultset directly to any rust structure that fits the data semantics.

hdbconnect implements this with the help of serde_db, a reusable library for simplifying the data exchange between application code and database drivers, both for input parameters (e.g. to prepared statements) and for results that are returned from the database.

In contrast to typical ORM mapping variants, this approach allows using the full flexibility of SQL (projection lists, all kinds of joins, unions, nested queries, etc). Whatever query you need, you just use it, without further ado for defining object models etc., and whatever result structure you want to read, you just use a corresponding rust structure into which you deserialize the data. It’s hard to use less code!

See code examples for an overview.

Re-exports

pub use r2d2;

Modules

Code examples.
Support for serializing from or deserializing into types of the time crate.
Non-standard types that are used within the HdbValues in a ResultSet.
Constants for use in connection URLs.

Structs

An immutable struct with all information necessary to open a new connection to a HANA database.
A builder for ConnectParams.
A synchronous connection to the database.
Implementation of r2d2’s ManageConnection interface.
Metadata of a field in a ResultSet.
Represents all possible non-error responses to a database command.
A set of output parameters, as they can be returned by procedure calls.
Metadata for a parameter.
Describes a set of IN, INOUT, and OUT parameters. Can be empty.
Allows injection-safe SQL execution and repeated calls of the same statement with different parameters with as few roundtrips as possible.
The result of a database query.
A single line of a ResultSet, consisting of the contained HdbValues and a reference to the metadata.
Describes an error that is reported from the database.
Describes the server-side resource consumption.

Enums

Describes the success of a command.
A list specifying categories of HdbError.
An enum that describes a single database return value.
Enum for all supported database value types.
Describes whether a parameter is Nullable or not or if it has a default value.
Describes whether a parameter is used for input, output, or both.
Expresses where Certificates for TLS are read from.
Severity of a server message
Describes whether and how TLS is to be used.
ID of the value type of a database column or a parameter.

Constants

Default value for the number of resultset lines that are fetched with a single FETCH roundtrip; the constant’s value is 100,000.
Number of bytes (for BLOBS and CLOBS) or 1-2-3-byte sequences (for NCLOBS) that are fetched in a single LOB READ roundtrip; the constant’s value is 16,000,000.
Number of bytes that are written in a single LOB WRITE roundtrip; the constant’s value is 16,000,000.

Traits

A trait implemented by types that can be converted into a ConnectParams.
A trait implemented by types that can be converted into a ConnectParamsBuilder.
Helper trait for serialization.

Type Definitions

Abbreviation of Result<T, HdbError>.