作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有以下代码:
#[async_std::main]
async fn main() -> tide::Result<()> {
let mut app = tide::new();
let pool = MySqlPoolOptions::new()
.max_connections(500)
.connect(&"mysql://root:root@127.0.0.1/test").await?;
app.at("/").get(|_req: Request<()>| async move {
let row: (i64,) = sqlx::query_as("select sleep(FLOOR(RAND()*10)) as s")
.fetch_one(&pool).await?;
Ok(Body::from_json(&row)?)
});
但是rust编译器提示
closure is FnOnce because it moves the variable pool out of its environment
。据我了解,这是一个由于借阅检查器而引起的问题:
pool
传递给闭包并在闭包上使用
move
语义来实现
sqlx
连接池设施与此类代码一起使用的正确方法是什么?这是我的第一个防 rust 程序,所以我还不太了解借位检查器
最佳答案
您应该使用应用程序状态并在其中存储池,这是example如何在请求处理程序中设置和使用状态
关于rust - 在闭包内共享连接池,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/65117107/
我正在尝试对 StockData 表执行 OHCL sql 查询 (SQL Server 2012)。每天有数千行添加到表中,我想获取每天的开盘价、最高价、最低价和收盘价数据。 建表sql如下:
我是一名优秀的程序员,十分优秀!