1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
//! SQLX traits implementation for Ydb
//! 
//! # Examples
//! 
//! ``` rust
//! # #[tokio::main]
//! # async fn main() -> Result<(), Box<dyn std::error::Error>> {
//!     use ydb_unofficial::sqlx::prelude::*;
//!     let token = std::env::var("DB_TOKEN").unwrap();
//!     let conn_str = format!("ydbs://ydb.serverless.yandexcloud.net:2135/ru-central1/b1gtv82sacrcnutlfktm/etn8sgrgdbp7jqv64k9f?token={token}");
//!     let options = YdbConnectOptions::from_str(&conn_str)?;
//!     let mut conn = options.connect().await?;
//!     query("create table my_test_table (id int32, text utf8, primary key(id));")
//!         .execute(conn.scheme_executor()?).await?;
//!     let result = query("declare $id as int32; declare $text as utf8; upsert into my_test_table(id, text) values($id, $text);")
//!         .bind(("$id",1))
//!         .bind(("$text", "one".to_owned()))
//!         .execute(conn.executor()?).await?;
//!     let row: (i32, String) = query_as("select * from my_test_table;")
//!         .fetch_one(conn.executor()?).await?;
//!     assert_eq!(row.0, 1);
//!     assert_eq!(row.1, "one");
//!     query("drop table my_test_table;")
//!         .execute(conn.scheme_executor()?).await?;
//! #   Ok(())
//! # }
//! ```

pub mod entities;
pub mod database;
pub mod error;

pub mod connection;
pub mod executor;
pub mod types;
pub mod statement;
//TODO: спрятать под фичу
mod minikql;

use super::error::YdbError;

pub mod prelude;

#[cfg(feature = "migrate")]
#[cfg_attr(docsrs, doc(cfg(feature = "migrate")))]
mod migration;