Crates.io | oracle_sql_tools |
lib.rs | oracle_sql_tools |
version | 0.2.0 |
source | src |
created_at | 2024-04-09 19:28:39.001486 |
updated_at | 2024-07-09 14:48:00.255505 |
description | An extension to the Rust-Oracle crate to make simple queries easy to implement. |
homepage | |
repository | https://github.com/Cosiamo/oracle_sql_tools |
max_upload_size | |
id | 1202754 |
size | 55,581 |
A crate that makes simple Oracle SQL queries easy to implement into your codebase. Built as an extension to the Rust-oracle crate (required).
Add these inside your cargo.toml
file:
[dependencies]
oracle_sql_tools = "0.1"
oracle = "0.5"
# chrono is required if you're working with dates
chrono = "0.4"
FormatData
Trait for Local EnumsTo use the .prep_data()
method on a vector or grid that uses an enum you created as the values, you need to implement the trait FormatData
for it.
enum MyEnum {
VARCHAR(String),
NUMBER(i64)
}
impl FormatData for MyEnum {
fn fmt_data(self) -> FormattedData {
match self {
MyEnum::VARCHAR(val) => FormattedData::STRING(val.into()),
MyEnum::NUMBER(val) => FormattedData::INT(val.into()),
}
}
}
FormatData
Trait for Foreign EnumsIf you need to implement the trait on a enum from a crate you imported:
use some_crate::SomeForeignType;
struct MyType<'a>(&'a SomeForeignType);
impl FormatData for MyType<'_> {
fn fmt_data(self) -> FormattedData {
match self.0 {
MyType(SomeForeignType::Int(val)) => FormattedData::INT(*val),
MyType(SomeForeignType::Float(val)) => FormattedData::FLOAT(*val),
MyType(SomeForeignType::String(val)) => FormattedData::STRING(val.to_owned()),
MyType(SomeForeignType::Date(val)) => FormattedData::DATE(*val),
MyType(SomeForeignType::DateTime(val)) => FormattedData::TIMESTAMP(*val),
MyType(SomeForeignType::None) => FormattedData::EMPTY,
}
}
}
let conn: oracle::Connection = match Connection::connect("<USERNAME>", "<PASSWORD>", "<IP ADDRESS>")?;
let col_names: Vec<&str> = vec!["Employee ID", "Name", "Job Title", "Department", "Business Unit"];
let table_data: Vec<Vec<Option<String>>> = col_names.prep_data(conn).select("MY_TABLE")?;
Is the same as:
SELECT employee_id, name, job_title, department, business_unit FROM my_table;
let conn: oracle::Connection = match Connection::connect("<USERNAME>", "<PASSWORD>", "<IP ADDRESS>")?;
let data: Vec<Vec<String>> = vec![
vec!["ColA".to_string(), "ColB".to_string(), "ColC".to_string()],
vec!["A1".to_string(), "B1".to_string(), "C1".to_string()],
vec!["A2".to_string(), "B2".to_string(), "C2".to_string()],
vec!["A3".to_string(), "B3".to_string(), "C3".to_string()],
];
// `res` is [oracle::Connection] that's Atomically Reference Counted
let res: Arc<Connection> = data.prep_data(conn).insert("MY_TABLE")?;
// `res` has the executed Batch(es), you only need to commit it
res.commit()?;
Ok(())
Is the same as:
INSERT ALL
INTO my_table (ColA, ColB, ColC) VALUES ('A1', 'B1', 'C1')
INTO my_table (ColA, ColB, ColC) VALUES ('A2', 'B2', 'C2')
INTO my_table (ColA, ColB, ColC) VALUES ('A3', 'B3', 'C3')
SELECT 1 FROM dual;
Or in Oracle 23c
:
INSERT INTO my_table (ColA, ColB, ColC) VALUES
('A1', 'B1', 'C1'),
('A2', 'B2', 'C2'),
('A3', 'B3', 'C3');