Crate hdbconnect
source ·Expand description
Synchronous 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.
Modules§
- Code examples.
- Support for serializing from or deserializing into types of the
time
crate. - Non-standard types that are used to represent database values.
- 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.
- A collection of settings that influence the runtime behavior of a connection.
- ConnectionManager
r2d2_pool
Implementation of r2d2’sManageConnection
. - Provides some statistics about the use of a concrete connection.
- 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.
- List of metadata of the fields of a resultset.
- A single line of a
ResultSet
, consisting of the containedHdbValue
s and a reference to the metadata. - Describes an error that is reported from the database.
- Describes the server-side resource consumption.
Enums§
- Holdability of cursors in the database.
- The errors that can arise while deserializing with
serde_db::de
. - 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.
- Error that can occur while serializing a standard rust type or struct into a SQL parameter.
- 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.
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 Aliases§
- Abbreviation of
Result<T, HdbError>
.