Akita is a mini framework for MySQL.
You may be looking for:
Click to show Cargo.toml.
Run this code in the playground.
```toml [dependencies]
akita = { version = "1.0", features = ["derive"] }
```
```rust use akita::; use akita::prelude::;
/// Annotion Support: Table、id、column (name, exist)
pub struct User {
#[id(name = "id")]
pub pk: i64,
pub id: String,
pub name: String,
pub headline: NaiveDateTime,
pub avatarurl: Option
impl Default for User { fn default() -> Self { Self { id: "".tostring(), pk: 0, name: "".tostring(), headline: mysql::chrono::Local::now().naivelocal(), avatarurl: "".tostring().into(), gender: 0, birthday: mysql::chrono::Local::now().naivelocal().date().into(), isorg: false, urltoken: "".tostring(), usertype: "".tostring(), status: 0, level: 1, data: vec![], innerstruct: TestInnerStruct { id: "".tostring(), }, innertuple: ("".tostring()), innerenum: TestInnerEnum::Field, } } }
pub struct TestInnerStruct { pub id: String, }
pub enum TestInnerEnum { Field, }
fn main() { // use r2d2 pool let pool = new_pool("mysql://root:127.0.0.1:3306/test", 4).unwrap(); let mut conn = pool.get().unwrap();
/// build the wrapper.
let mut wrapper = UpdateWrapper::new()
.like(true, "username", "ffff");
.eq(true, "username", 12);
.eq(true, "username", "3333");
.in_(true, "username", vec![1,44,3]);
.not_between(true, "username", 2, 8);
.set(true, "username", 4);
let user = User::default();
let mut conn = ConnMut::Pooled(&mut conn);
// Transaction
conn.start_transaction(TxOpts::default()).map(|mut transaction| {
match user.update( & mut wrapper, &mut ConnMut::TxMut(&mut transaction)) {
Ok(res) => {}
Err(err) => {
println!("error : {:?}", err);
}
}
});
/// update by identify
match user.update_by_id(&mut conn) {
Ok(res) => {}
Err(err) => {
println!("error : {:?}", err);
}
}
/// delete by identify
match user.delete_by_id(&mut conn) {
Ok(res) => {}
Err(err) => {
println!("error : {:?}", err);
}
}
/// delete by condition
match user.delete:: < UpdateWrapper > ( & mut wrapper, &mut conn) {
Ok(res) => {}
Err(err) => {
println!("error : {:?}", err);
}
}
/// insert data
match user.insert(&mut conn) {
Ok(res) => {}
Err(err) => {
println!("error : {:?}", err);
}
}
/// find by identify
match user.find_by_id(&mut conn) {
Ok(res) => {}
Err(err) => {
println!("error : {:?}", err);
}
}
/// find one by condition
match user.find_one::<UpdateWrapper>(&mut wrapper, &mut conn) {
Ok(res) => {}
Err(err) => {
println!("error : {:?}", err);
}
}
/// find page by condition
match user.page::<UpdateWrapper>(1, 10,&mut wrapper, &mut conn) {
Ok(res) => {}
Err(err) => {
println!("error : {:?}", err);
}
}
} ```
Table
- to make Akita work with structscolumn
- to make struct field with own database.name
- work with column, make the table's field name. default struct' field name.exist
- ignore struct's field with table. default true.Option<T>
u8, u32, u64
i32, i64
usize
bool
f32, f64
str, String
NaiveDate, NaiveDateTime
To setup the development envrionment run cargo run
.
MrPan <1049058427@qq.com>
Akita is a personal project. At the beginning, I just like Akita dog because of my hobbies. I hope this project will grow more and more lovely. Many practical database functions will be added in the future. I hope you can actively help this project grow and put forward suggestions. I believe the future will be better and better.
Licensed under either of Apache License, Version 2.0 or MIT license at your option.
Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in Akita by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.