rust操作pgsql、mysql和sqlite

rust中,有很多技术可以操作pgsql、mysql和sqlite,以sqlx为主流技术。我们以sqlx操作sqlite为示例,操作pgsql和mysql的办法是一样的。

复制代码
Cargo.toml:
rust 复制代码
[package]
name = "test"
version = "0.1.0"
edition = "2021"

[dependencies]
serde = { version = "1", features = ["derive"] }
serde_json = "1"
sqlx = {  version ="0.8.3", features = [ "runtime-tokio", "tls-rustls-ring", "mysql","postgres","sqlite", "time", "uuid", "chrono" ] }
axum = {   version ="0.7.7", features = ["multipart"] }
tokio = { version = "1.0", features = ["full"] }
tracing = "0.1"
tracing-subscriber = { version = "0.3", features = ["env-filter"] }
tracing-appender = "0.2"
futures = "0.3.31"
tower-http =  { version ="0.6.1", features = ["cors", "fs", "compression-gzip"] }
chrono = { version = "0.4", features = ["serde"] }
tokio-util = { version = "0.7", features = ["io","compat"] }
 tower="0.5.1"
 thiserror = "1.0"
复制代码
main.rs:
rust 复制代码
use crate::entity::*;
use axum::routing::post;
use axum::{
    extract::Extension, http::StatusCode, response::IntoResponse, routing::get, Json, Router,
};
use axum::{
    extract::State,
    extract::{Path, Query},
};
use axum::{
    extract::{FromRef, FromRequestParts},
    http::request::Parts,
};
use serde::{Deserialize, Serialize};
use std::{env, option};
use thiserror::Error;
use tokio_stream::StreamExt; // 用于处理异步流
mod entity;
use axum::extract::DefaultBodyLimit;
use axum::extract::Query as axumQuery;
use sqlx::encode::IsNull;
use sqlx::mysql::{MySqlPool, MySqlPoolOptions};
use sqlx::postgres::{PgPool, PgPoolOptions};
use sqlx::sqlite::SqlitePoolOptions;
use sqlx::sqlite::{SqliteOperation, SqlitePool};
use sqlx::{mysql::MySqlQueryResult, mysql::MySqlRow, postgres::PgQueryResult, postgres::PgRow, Sqlite};
use sqlx::{sqlite::SqliteQueryResult, sqlite::SqliteRow, Column, FromRow, Row, TypeInfo};
use std::collections::HashMap;
use std::error::Error;
use std::path::Path as stdPath;
use std::path::PathBuf;
use std::process::Stdio;
use std::sync::atomic::{AtomicUsize, Ordering};
use tokio::net::TcpStream;
use tokio::process::Command; // 使用 tokio 的异步 Command
use tokio::task;
use tokio_util::compat::TokioAsyncWriteCompatExt;
use tower_http::cors::{Any as OtherAny, CorsLayer};
use tracing::{debug, info, warn};
use tracing_appender::rolling;
use tracing_subscriber::fmt::writer::MakeWriterExt;
use oracle::sql_type;
use libloading::{Library, Symbol};
use std::ffi::{CStr, CString};
use std::os::raw::c_char;
use std::os::raw::c_int;
use sysinfo::{System};
use std::fs::{File, OpenOptions};
use std::io::{Read, Write};
use std::sync::Arc;
use once_cell::sync::Lazy;
use std::sync::Mutex;
#[tokio::main]
async fn main() {
//创建连接
 let database_url = "sqlite::memory:";
    let sqliteconnection = SqlitePoolOptions::new()
        .max_connections(5)
        .connect(&database_url)
        .await
        .expect("数据库连接失败");
 let create_table_1 = "CREATE TABLE test(c1 TEXT   COLLATE NOCASE , c2 TEXT   COLLATE NOCASE );";
//执行sql语句
    sqlx::query(create_table_1)
        .execute(&sqliteconnection )
        .await
        .expect("创建表失败");
}

代码来源为hpctb真实代码的简化。

相关推荐
微学AI6 分钟前
Rust语言的深度剖析:内存安全与高性能的技术实现操作
java·安全·rust
百***99244 小时前
MySql的慢查询(慢日志)
android·mysql·adb
q***13345 小时前
在linux(Centos)中Mysql的端口修改保姆级教程
linux·mysql·centos
理想三旬5 小时前
关系数据库
数据库
千寻技术帮6 小时前
50022_基于微信小程序同城维修系统
java·mysql·微信小程序·小程序·同城维修
无心水6 小时前
【分布式利器:RocketMQ】2、RocketMQ消息重复?3种幂等方案,彻底解决重复消费(附代码实操)
网络·数据库·rocketmq·java面试·消息幂等·重复消费·分布式利器
q***98527 小时前
基于人脸识别和 MySQL 的考勤管理系统实现
数据库·mysql
l1t7 小时前
用SQL求解advent of code 2024年23题
数据库·sql·算法
办公解码器8 小时前
Excel工作表打开一次后自动销毁文件,回收站中都找不到
数据库·excel
Source.Liu8 小时前
【Chrono库】WeekdaySet 星期几集合实现解析(weekday_set.rs)
rust·time