-
-
Notifications
You must be signed in to change notification settings - Fork 48
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
After update to CraftCMS 4.9.5 mapsCalculatedDistance Column not found #391
Comments
The error happens when filtering out entries based on location and radius. |
I'm seeing the same issue |
Unfortunately the issue makes the plugin unusable, since the main reason we add this plugin is to search by location and radius. Hopefully it can be fixed soon? May look to downgrade Craft CMS if not. |
I have already downgraded Craft CMS because a significant part of my website relies on search by location and radius. I hope this can be fixed soon. |
Same here. And confirmed: Downgrading to Craft 3.9.4 fixed the issue. Something happed in Craft 3.9.5 specifically to break this. |
Same here. Specifically on the COUNT query for us, it's related to the way craft recently changed the way it handles scalar queries and further update in 4.9.5 changed the way the SELECT value was handled see changelog:
Exactly the same issue here: |
I'm no mysql expert and but having a quick look over this, moving the query condition that checks the radius into a WHERE condition rather than the HAVING condition currently used looks to fix this specific issue. Not knowing the plugin, i'm not sure if there are any knock on implications of this, but it does't look like the HAVING method works off any groupings, so WHERE should cover it. Not throughly tested the impact on performance, but appears minimal in the very specific scenario i have tested in. So removing this block: simplemap/src/services/MapService.php Lines 385 to 388 in 07594b0
And adding the WHERE condition $query
->subQuery
->addSelect($search . ' as [[mapsCalculatedDistance]]')
->andWhere($restrict)
->andWhere($search . ' <= ' . $radius)
->andWhere([
'not',
['[[' . $table . '.lat]]' => null],
]); Any thoughts @Tam? |
I've got this as well. I didn't catch it before releasing and appeared to have a spike in Google API usage during the period I updated too which I'm investigating. |
Hi @Tam sorry to chase this one, appreciate you are busy, but this is pretty critical as we are stuck unable to update Craft beyond 4.9.4. I am happy to put in a PR to try and patch, but having very limited understanding of the location query sql logic, I would be wary of inadvertently causing issues elsewhere. It would be great if you could take a look at my thoughts above (#391 (comment)) I have also reached out to Craft to see if they have any insight in how this should be implemented as a result of the changes in 4.9.5. |
Thanks for jumping on this @Tam Not tested yet, but won’t this impact all scalar queries, any query that relies on the |
Just following up on this @Tam, the fix does work on the |
Craft 4.10.2 and 5.2.2 are out with a fix for this. |
After I update from CraftCMS 4.9.4 to 4.9.5, I get the following error:
SQLSTATE[42S22]: Column not found: 1054 Unknown column 'mapsCalculatedDistance' in 'having clause'.
The text was updated successfully, but these errors were encountered: