当我使用rust sqlx执行SQL语句时,发现返回结果不正确。对于同样的语句,当我使用pysql时,我得到的结果与从MySQL客户端查询得到的结果一致。我不知道为什么会这样;某些 SQL 函数似乎可能存在问题。
这是 SQL:
SELECT COUNT(*),MAX(STR_TO_DATE(occurtime, '%Y-%m-%d %H:%i:%s')) FROM rulelog
WHERE STR_TO_DATE(occurtime, '%Y-%m-%d %H:%i:%s') BETWEEN DATE_FORMAT(NOW(), '%Y-%m-%d 00:00:00') AND NOW()
在 Rust sqlx 中:
let sql = format!(r#"SELECT COUNT(*),MAX(STR_TO_DATE(occurtime, '%Y-%m-%d %H:%i:%s')) FROM rulelog WHERE STR_TO_DATE(occurtime, '%Y-%m-%d %H:%i:%s') BETWEEN DATE_FORMAT(NOW(), '%Y-%m-%d 00:00:00') AND NOW()"#);
match sqlx::query(sql.as_str())
.fetch_one(&pool)
.await {
Ok(res) => {
log::info!("res: {:?}", res);
log::info!("res: {:?}, {:?}", res.get::<i32, _>(0), res.get::<Option<String>, _>(1));
}
Err(e) => {
log::error!("{e}");
return;
}
};
sqlx 输出:
[2023-07-20 15:30:35] INFO [evi_saver::save_evi_layer::test] src/save_evi_layer.rs:437: res: MySqlRow { row: Row { storage: b"\x08\0\0\0\0\0\0\0\0", values: [Some(1..9), None] }, format: Binary, columns: [MySqlColumn { ordinal: 0, name: COUNT(*), type_info: MySqlTypeInfo { type: LongLong, flags: ColumnFlags(NOT_NULL | BINARY), char_set: 63, max_size: Some(21) }, flags: Some(ColumnFlags(NOT_NULL | BINARY)) }, MySqlColumn { ordinal: 1, name: MAX(STR_TO_DATE(occurtime, '%Y-%m-%d %H:%i:%s')), type_info: MySqlTypeInfo { type: VarString, flags: ColumnFlags(0x0), char_set: 224, max_size: Some(76) }, flags: Some(ColumnFlags(0x0)) }], column_names: {COUNT(*): 0, MAX(STR_TO_DATE(occurtime, '%Y-%m-%d %H:%i:%s')): 1} }
[2023-07-20 15:30:35] INFO [evi_saver::save_evi_layer::test] src/save_evi_layer.rs:438: res: 0, None
在 pymysql 中:
cursor = db.cursor()
sql = """SELECT COUNT(*),MAX(STR_TO_DATE(occurtime, '%Y-%m-%d %H:%i:%s')) FROM rulelog WHERE STR_TO_DATE(occurtime, '%Y-%m-%d %H:%i:%s') BETWEEN DATE_FORMAT(NOW(), '%Y-%m-%d 00:00:00') AND NOW()"""
cursor.execute(sql)
res = cursor.fetchall()
print(res)
pymysql 输出:
((39, '2023-07-20 15:08:33'),)
mysql客户端输出:
mysql> SELECT COUNT(*), MAX(STR_TO_DATE(occurtime, '%Y-%m-%d %H:%i:%s')) FROM rulelog WHERE STR_TO_DATE(occurtime, '%Y-%m-%d %H:%i:%s') BETWEEN DATE_FORMAT(NOW(), '%Y-%m-%d 00:00:00') AND NOW();
+----------+--------------------------------------------------+
| COUNT(*) | MAX(STR_TO_DATE(occurtime, '%Y-%m-%d %H:%i:%s')) |
+----------+--------------------------------------------------+
| 39 | 2023-07-20 15:08:33 |
+----------+--------------------------------------------------+
1 row in set (0.03 sec)
信息
SQLx version: [0.7.1]
SQLx features enabled: ["mysql", "runtime-tokio", "runtime-tokio-native-tls"]
Database server and version: [MySQL 5.7.42-0ubuntu0.18.04.1 (Ubuntu)] (MySQL / Postgres / SQLite <x.y.z>)
Operating system: [ubuntu0.18.04.1]
rustc --version: [rustc 1.72.0-nightly (839e9a6e1 2023-07-02)]
let mut pool = sqlx::mysql::MySqlPoolOptions::new()
// set timezone
.after_connect(|conn, _meta| Box::pin(async move {
conn.execute("SET time_zone = SYSTEM;").await?;
Ok(())
}))
.max_connections(2).connect(mysql_url.as_str()).await.unwrap();