i have implemented the mysql query in rust, but i select causes an error.
This is the error the trait `diesel::expression::MixedAggregates<diesel::expression::is_aggregate::Yes>` is not implemented for `diesel::expression::is_aggregate::No
Whats the problem and how can i fix this?
let sub = progress::table
.filter(progress::user.eq(1))
.group_by(progress:: otherid)
.select((diesel::dsl::max(progress::updated), progress::otherid, progress::onemoreid));
SELECT otherid, onemoreid, MAX(updated) AS newest_updated
FROM progress
WHERE user = 1
GROUP BY otherid
EDIT: the error doesnt occur when i dont have progress::onemoreid in select.
The relevant part from diesel documentation is the following paragraph:
This restriction is in place because otherwise your query could return non-deterministic results. After all, what value of
onemoreid
should be selected when the query produces multiple possible values.MySQL allows to write such queries, but they can return non-deterministic results there. That means that just some value is returned. Possibly even different values for the execution of the same query using the same data.