- Speed hacks for the Newspaper theme by tagDiv: Transform your site speed - February 19, 2025
- WooCommerce 9.6.1 can break your store if you use brands - February 7, 2025
- Discord Performance Community Server and some new server rules - November 27, 2024
A customer of mine was struggling with an import. After activating the Slow Query Log inside Scalability Pro I discovered they had a slow query coming from a plugin called WPNotif. This plugin is sold by Code Canyon and lets you send WhatsApp messages to your customers – quite cool!
data:image/s3,"s3://crabby-images/fdfbc/fdfbc586fc27477b67a47063f6fbee23f417267e" alt="Settings page Scalability Pro to access the Slow Query Log"
They have a slow query however which you won’t notice at first, but once your site gets larger you’ll notice a big slowdown which hurts your server.
data:image/s3,"s3://crabby-images/5adde/5adde72936b67fc34d76df48ec745a4625a1dbbe" alt=""
WPNotif’s table structure
They create a table called wpnotif_wc_cart_sessions. This table comes with 2 indexes by default but no index for the slow query we discovered.
data:image/s3,"s3://crabby-images/a90c5/a90c5fa0bb55cadf049bdb0f25ac212915760da8" alt=""
Adding a suitable index for making the WPNotif plugin faster
The slow query is doing an equals operation on the notif_status column and a less-than operation on the time column. When it comes to matching indexes up to queries, the order of the columns in the indexes matters. Basically – any columns where the query performs an equals operation should come first in the index with greater-than and less-than columns coming at the end of the index.
MySQL will benefit from an index when performing a less-than or greater-than operation but it can only really optimise ONE of these operations in the query. After that, the remaining data needs to be scanned.
So – that means our index should be on notif_status and then time.
data:image/s3,"s3://crabby-images/01218/01218526a5f3848a36ad820590ff40971ae72549" alt=""
Now the query takes 0.001s instead of 0.329s. Note this would only have gotten worse for this customer – the more customers and cart sessions they had, the slower their website and notifications service would have become.