You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
I have a use case where I need to iterate over the result of a query and use the row data to update the row. Here is a small example program illustrating the scenario:
use mysql::prelude::Queryable;use mysql::{from_row,Conn};fnmain(){let url = "mysql://root@localhost:3306/vitrosearch_fmimport";letmut conn = Conn::new(url).unwrap();// Create a table and fill in some data
conn.exec_drop("create temporary table test (id int not null, text varchar(10) null)",()).unwrap();for n in1..101{
conn.exec_drop("insert into test (id) values (?)",(n,)).unwrap();}// Select the data in the table and update each row accordinglyletmut result = conn.query_iter("select id from test").unwrap();whileletSome(row) = result.next(){let r:(i32,) = from_row(row.unwrap());let text = format!("{}",r.0);
conn.exec_drop("update test set text = ? where id = ?",(r.0, text)).unwrap();}}
This example cannot be compiled because the connection would be mutably borrowed two times, once when executing the select statement and a second time, when trying to execute the update statement:
error[E0499]: cannot borrow `conn` as mutable more than once at a time
--> src\main.rs:17:9
|
13 | let mut result = conn.query_iter("select id from test").unwrap();
| ---- first mutable borrow occurs here
14 | while let Some(row) = result.next() {
| ------ first borrow later used here
...
17 | conn.exec_drop("update test set text = ? where id = ?", (r.0, text)).unwrap();
| ^^^^ second mutable borrow occurs here
Is there a possibility to implement this use case with the mysql crate? Reading all the data to memory first and then executing all the update statements after that is not an option because in the real-world use case we are not dealing with 100 records but with millions of records.
The text was updated successfully, but these errors were encountered:
I have a use case where I need to iterate over the result of a query and use the row data to update the row. Here is a small example program illustrating the scenario:
This example cannot be compiled because the connection would be mutably borrowed two times, once when executing the select statement and a second time, when trying to execute the update statement:
Is there a possibility to implement this use case with the mysql crate? Reading all the data to memory first and then executing all the update statements after that is not an option because in the real-world use case we are not dealing with 100 records but with millions of records.
The text was updated successfully, but these errors were encountered: