I’m working on a query to calculate the total sum of enrollments for different student types (traditional and dual credit). Here's the query I’m using:
SELECT gr_house_enrollments.`campus_id`, gr_house_enrollments.`district_id`, gr_house_enrollments.`program_id`, gr_house_enrollments.`student_type`, gr_house_enrollments.`students_count`, SUM(CASE WHEN gr_house_enrollments.student_type = 'traditional' THEN gr_house_enrollments.students_count ELSE 0 END) AS `total_traditional_enrollments`, SUM(CASE WHEN gr_house_enrollments.student_type = 'dual credit' THEN gr_house_enrollments.students_count ELSE 0 END) AS `total_dual_credit_enrollments`
FROM gr_house_enrollments
WHERE gr_house_enrollments.`term` LIKE '%23/FA%'
GROUP BY gr_house_enrollments.`campus_id`, gr_house_enrollments.`program_id`, gr_house_enrollments.`student_type`
However, I encounter the following error:
WordPress database error: [Unknown column 'total_dual_credit_enrollments' in 'field list']
It seems like the error is related to the column alias total_dual_credit_enrollments. I suspect the issue might be due to a problem with how the aliases or groupings are structured, but I’m not entirely sure what’s causing it.
Could you help identify the issue and suggest how to calculate the total sum of all enrollments across these categories?
Our SQL Feature is not the same as a Database Management Tool, so for example - a specific Custom Query might work in your SQL Database directly but not in our SQL Feature of the Plugin, because we run everything through our PHP & SQL Parser, which has certain limitations.
We will do our best to advise.
On this documentation, there are more details which explain how our server-side processing works :
Basically, when the server-side option in a Table is enabled, the wpDataTables will give the search results through the Query;
So, our Plugin sends the Query to the database.
If that Query is formatted as
"SELECT ...
FROM ...
WHERE... "
but after the "FROM" if it has any complex Query, there can be errors;
as we mentioned, our SQL Query feature does not work in the same way as a Database Management Tool ( such as PHPMyAdmin and similar),
and is not meant to be used as one;
it is based on an SQL Parser which has limitations;
so it can happen that a specific complex Query might work in PhpMyAdmin but struggles to work through our server-side processing ( and the SQL Parser);
So when the Server-Side is enabled, our plugin sends a more complex SQL Query which in this case is too complicated for our Parser to handle,
instead of when the server-side is disabled, it just simply filters the data just by the values already seen in the column.
I hope that this helps to clarify everything, did my best to pass our developer Team's explanations.
So to solve this particular issue, you would need to either try and somehow simplify your SQL Query in order for our server-side processing to work;
or if you can make it work without server-side processing, if your data/number of rows of the table does not become too large, let's say above 4, 5, 6 thousand rows, and if the hosting server performs well,
you can 'get away' with disabling server-side on the table and see if that helps.
Here is how you can 'raise' the limit of rows for "server-side processing" toggle.
If your SQL query based tables are not bigger than 2.000 rows,
you can disable server-side on SQL tables, and it will work like it does for Excel tables. ( loads all rows regardless of pagination)
If you need to increase the row count while still having the "toggle" to disable server-side,
Please go to ../wp-content/plugins/wpdatatables/source/class.wpdatatable.php and around line 2176 you'll see this:
if (count($res_dataRows) > 2000) {
You can change that number to a value bigger than the number of rows in your table.
Same should be applied in ../wp-content/plugins/wpdatatables/source/class.wdtconfigcontroller.php on lines 53:
if (count($wpDataTable->getDataRows()) > 2000) {
And line 100:
if (count($wpDataTable->getDataRows()) > 2000) {
That will increase the server-side automatic limit.
Let us know if you manage to simplify the Query for our Parser, or if disabling Server-Side processing helps;
If none of that helps,
you can try preparing a MySQL view (which will return the data that you need, call it e.g. “view1” and then build a wpDataTables based on a simple query like "SELECT * FROM view1″.
If you need help with that, you can see our video, where we show an example of using View in our plugin.
I hope one of these methods might solve the issue.
I’m working on a query to calculate the total sum of enrollments for different student types (traditional and dual credit). Here's the query I’m using:
However, I encounter the following error:
WordPress database error: [Unknown column 'total_dual_credit_enrollments' in 'field list']
It seems like the error is related to the column alias total_dual_credit_enrollments. I suspect the issue might be due to a problem with how the aliases or groupings are structured, but I’m not entirely sure what’s causing it.
Could you help identify the issue and suggest how to calculate the total sum of all enrollments across these categories?
Hi Rodolfo,
I will do my best to advise on this use case.
Our SQL Feature is not the same as a Database Management Tool, so for example - a specific Custom Query might work in your SQL Database directly but not in our SQL Feature of the Plugin, because we run everything through our PHP & SQL Parser, which has certain limitations.
We will do our best to advise.
On this documentation, there are more details which explain how our server-side processing works :
https://wpdatatables.com/documentation/table-features/server-side-processing/.
Basically, when the server-side option in a Table is enabled, the wpDataTables will give the search results through the Query;
So, our Plugin sends the Query to the database.
If that Query is formatted as
"SELECT ...
FROM ...
WHERE... "
but after the "FROM" if it has any complex Query, there can be errors;
as we mentioned, our SQL Query feature does not work in the same way as a Database Management Tool ( such as PHPMyAdmin and similar),
and is not meant to be used as one;
it is based on an SQL Parser which has limitations;
so it can happen that a specific complex Query might work in PhpMyAdmin but struggles to work through our server-side processing ( and the SQL Parser);
So when the Server-Side is enabled, our plugin sends a more complex SQL Query which in this case is too complicated for our Parser to handle,
instead of when the server-side is disabled, it just simply filters the data just by the values already seen in the column.
I hope that this helps to clarify everything, did my best to pass our developer Team's explanations.
So to solve this particular issue, you would need to either try and somehow simplify your SQL Query in order for our server-side processing to work;
or if you can make it work without server-side processing, if your data/number of rows of the table does not become too large, let's say above 4, 5, 6 thousand rows, and if the hosting server performs well,
you can 'get away' with disabling server-side on the table and see if that helps.
Here is how you can 'raise' the limit of rows for "server-side processing" toggle.
If your SQL query based tables are not bigger than 2.000 rows,
you can disable server-side on SQL tables, and it will work like it does for Excel tables. ( loads all rows regardless of pagination)
If you need to increase the row count while still having the "toggle" to disable server-side,
Please go to ../wp-content/plugins/wpdatatables/source/class.wpdatatable.php and around line 2176 you'll see this:
You can change that number to a value bigger than the number of rows in your table.
Same should be applied in ../wp-content/plugins/wpdatatables/source/class.wdtconfigcontroller.php on lines 53:
And line 100:
That will increase the server-side automatic limit.
Let us know if you manage to simplify the Query for our Parser, or if disabling Server-Side processing helps;
If none of that helps,
you can try preparing a MySQL view (which will return the data that you need, call it e.g. “view1” and then build a wpDataTables based on a simple query like "SELECT * FROM view1″.
If you need help with that, you can see our video, where we show an example of using View in our plugin.
I hope one of these methods might solve the issue.
Kind Regards,
Miloš Jovanović
[email protected]
Rate my support
Try our FREE mapping plugin! MapSVG - easy Google maps, interactive SVG maps and floor plans, choropleth maps and much more - https://wordpress.org/plugins/mapsvg-lite-interactive-vector-maps/
wpDataTables: FAQ | Facebook | Twitter | Instagram | Front-end and back-end demo | Docs
Amelia: FAQ | Facebook | Twitter | Instagram | Amelia demo sites | Docs | Discord Community
You can try wpDataTables add-ons before purchasing on these sandbox sites:
Powerful Filters | Gravity Forms Integration for wpDataTables | Formidable Forms Integration for wpDataTables | Master-Detail Tables