Crate odbc [] [src]

ODBC

Open Database Connectivity or short ODBC is a low level high performance interface introduced by Microsoft to access relational data stores. This crate wraps the raw C interface and is intended to be usable in safe and idiomatic Rust.

What is ODBC?

ODBC Programmer's Reference

Internal Desgin

While designed as a relatively low level wrapper around ODBC this crate tries to prevent many errors at compile time. The borrow checker and the RAII (Resource Acquisition Is Initialization) idiom should prevent any occurence of SQL_INVALID_HANDLE in safe code.

Using the type system and the borrow checker this crate ensures that each method call happens in a valid state and state transitions are modeled in the type system. This should eliminate the possibility of function sequence errors in safe code.

Basic ODBC Application Steps

ODBC State Transitions

Modules

ffi

Reexport odbc-sys as ffi

Structs

Cursor

Used to retrieve data from the fields of a query result

DataSource

Represents a connection to an ODBC data source

DataSourceInfo

Holds name and description of a datasource

DiagnosticRecord

ODBC Diagnostic Record

DriverInfo

Struct holding information available on a driver.

EnvAllocError

Environment allocation error

Environment

Handle to an ODBC Environment

Statement

A Statement can be used to execute queries and retrieves results.

Enums

Allocated

Statement state used to represent a freshly allocated connection

Connected

DataSource state used to represent a connection to a data source.

Disconnected

DataSource state used to represent a data source handle which not connected to a data source.

HasResult

Statement state used to represent a statement with a result set cursor. A statement is most likely to enter this state after a SELECT query.

NoResult

Statement state used to represent a statement with no result set. A statement is likely to enter this state after executing e.g. a CREATE TABLE statement

NoVersion

Environment state used to represent that no odbc version has been set.

Prepared

Statement state used to represent a statement compiled into an access plan. A statement will enter this state after a call to Statement::prepared

ResultSetState

Holds a Statement after execution of a query.Allocated

Version3

Environment state used to represent that environment has been set to odbc version 3

Traits

GetDiagRec

Allows retriving a diagnostic record, describing errors (or lack thereof) during the last operation.

Handle

Reflects the ability of a type to expose a valid handle

InputParameter

Allows types to be used with Statement::bind_parameter

Output

Indicates that a type can be retrieved using Cursor::get_data

Type Definitions

Executed

Statement state used to represent a statement with a result set cursor. A statement is most likely to enter this state after a SELECT query.

Result

Result type returned by most functions in this crate