登录
首页 >  数据库 >  MySQL

Rust简化版MybatisPlus - 让你一天从Java转业Rust

来源:SegmentFault

时间:2023-02-16 15:34:21 220浏览 收藏

积累知识,胜过积蓄金银!毕竟在##column_title##开发的过程中,会遇到各种各样的问题,往往都是一些细节知识点还没有掌握好而导致的,因此基础知识点的积累是很重要的。下面本文《Rust简化版MybatisPlus - 让你一天从Java转业Rust》,就带大家讲解一下MySQL、Java、ORM、rust、mybatis-plus知识点,若是你对本文感兴趣,或者是想搞懂其中某个知识点,就请你继续往下看吧~

算起来,从真正开始用

[dependencies]

# The core APIs, including the Table traits. Always
# required when using Akita. using #[derive(Table)] 
# to make Akita work with structs defined in your crate.
akita = { version = "0.2.0"] }

首先我们定义一个结构体

#[derive(Debug, FromAkita, ToAkita, Table, Clone)]
#[table(name="t_system_user")]
struct SystemUser {
    #[field = "name"]
    id: Option,
    #[table_id]
    username: String,
    #[field(name="ages", exist = "false")]
    age: i32,
}

来来来,

use akita::*;
use akita::prelude::*;

fn main() {
    let mut pool = Pool::new(AkitaConfig{ max_size: None, url: String::from("mysql://root:password@localhost:3306/akita"), log_level: None }).unwrap();
    let mut em = pool.entity_manager().expect("must be ok");
    let user = SystemUser { id: 1.into(), username: "fff".to_string(), age: 1 };

    // 新增
    match em.save(&user) {
        Ok(res) => { }
        Err(err) => { }
    }
    /// 结构体示例
    match user.insert(&mut em) {
        Ok(res) => { }
        Err(err) => { }
    }

    // 删除
    match em.remove_by_id::("id".to_string()) {
        Ok(res) => { }
        Err(err) => { }
    }

    // 修改
    match em.update_by_id(&user, "id") {
        Ok(res) => { }
        Err(err) => { }
    }

    // 查询分页
    let mut wrapper = UpdateWrapper::new();
    wrapper.eq( "username", "ussd").eq("id", 1);
    match em.page::(1, 10,&mut wrapper) {
        Ok(res) => { }
        Err(err) => { }
    }
    // 查询单条
    match em.select_one::(&mut wrapper) {
        Ok(res) => { }
        Err(err) => { }
    }

    ...
}

看完是不是很感动,对于手写了大半年SQL的我,简直是个福音...另外性能方面的话还有很多我们正在优化,比如大数据量的分页以及相关慢SQL的拦截以及一些其他的优化。

计划

项目目前只有几个人进行维护,所以未来更新速度并不会很快,我们也会在生产上使用这个框架,逐步的去优化。未来我们计划做的事:

  • 支持
    ORACLE
    ClickHouse
    SQLite
    MSSQL
    多个feature
  • 强化注解,增加配置映射,支持更多自定义的注解
  • 支持更多数据结构,优化内部参数处理
  • 完善自动代码生成工具,减少重复工作

码完跑路(偷懒)

所以接下来就是你们的时间了,该抄的抄,该溜的溜了。(逃

本篇关于《Rust简化版MybatisPlus - 让你一天从Java转业Rust》的介绍就到此结束啦,但是学无止境,想要了解学习更多关于数据库的相关知识,请关注golang学习网公众号!

声明:本文转载于:SegmentFault 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>
评论列表