mirror of
https://github.com/e107inc/e107.git
synced 2025-10-24 11:16:22 +02:00
Issue #5472 SQL_CALC_FOUND_ROWS is deprecated since MySQL 8.0.
This commit is contained in:
@@ -4592,7 +4592,7 @@ class e_admin_controller_ui extends e_admin_controller
|
|||||||
*/
|
*/
|
||||||
public function getParentChildQry($orderby=false)
|
public function getParentChildQry($orderby=false)
|
||||||
{
|
{
|
||||||
return 'SELECT SQL_CALC_FOUND_ROWS * FROM `#' .$this->getTableName(). '` ';
|
return 'SELECT * FROM `#' .$this->getTableName(). '` ';
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -5229,7 +5229,7 @@ class e_admin_controller_ui extends e_admin_controller
|
|||||||
//file_put_contents(e_LOG.'uiAjaxResponseFields.log', print_r($this->getFields(), true)."\n\n", FILE_APPEND);
|
//file_put_contents(e_LOG.'uiAjaxResponseFields.log', print_r($this->getFields(), true)."\n\n", FILE_APPEND);
|
||||||
if($joinData)
|
if($joinData)
|
||||||
{
|
{
|
||||||
$qry = 'SELECT SQL_CALC_FOUND_ROWS ' . $tableSFields;
|
$qry = 'SELECT ' . $tableSFields;
|
||||||
foreach($joinData as $jtable => $tparams)
|
foreach($joinData as $jtable => $tparams)
|
||||||
{
|
{
|
||||||
// Select fields
|
// Select fields
|
||||||
@@ -5287,7 +5287,7 @@ class e_admin_controller_ui extends e_admin_controller
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
$qry = 'SELECT SQL_CALC_FOUND_ROWS ' . $tableSFields . ' FROM ' . $tableFrom;
|
$qry = 'SELECT ' . $tableSFields . ' FROM ' . $tableFrom;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
@@ -5437,7 +5437,10 @@ class e_admin_controller_ui extends e_admin_controller
|
|||||||
|
|
||||||
|
|
||||||
// Print to the debug interface (optional, can overload logs)
|
// Print to the debug interface (optional, can overload logs)
|
||||||
e107::getMessage()->addDebug('<pre>' . $jsonDebugInfo . '</pre>');
|
if(E107_DEBUG_LEVEL == E107_DBG_SQLQUERIES)
|
||||||
|
{
|
||||||
|
e107::getMessage()->addDebug('<pre>' . $jsonDebugInfo . '</pre>');
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
return $qry;
|
return $qry;
|
||||||
@@ -6542,11 +6545,6 @@ class e_admin_ui extends e_admin_controller_ui
|
|||||||
|
|
||||||
$this->addTitle();
|
$this->addTitle();
|
||||||
|
|
||||||
// if($this->getQuery('filter_options'))
|
|
||||||
{
|
|
||||||
// var_dump($this);
|
|
||||||
// $this->addTitle("to-do"); // display filter option when active.
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -3459,7 +3459,7 @@ class e_tree_model extends e_front_model
|
|||||||
// auto-load all
|
// auto-load all
|
||||||
if(!$this->getParam('db_query') && $this->getModelTable())
|
if(!$this->getParam('db_query') && $this->getModelTable())
|
||||||
{
|
{
|
||||||
$this->setParam('db_query', 'SELECT'.(!$this->getParam('nocount') ? ' SQL_CALC_FOUND_ROWS' : '')
|
$this->setParam('db_query', 'SELECT'.(!$this->getParam('nocount') ? '' : '')
|
||||||
.($this->getParam('db_cols') ? ' '.$this->getParam('db_cols') : ' *').' FROM #'.$this->getModelTable()
|
.($this->getParam('db_cols') ? ' '.$this->getParam('db_cols') : ' *').' FROM #'.$this->getModelTable()
|
||||||
.($this->getParam('db_joins') ? ' '.$this->getParam('db_joins') : '')
|
.($this->getParam('db_joins') ? ' '.$this->getParam('db_joins') : '')
|
||||||
.($this->getParam('db_where') ? ' WHERE '.$this->getParam('db_where') : '')
|
.($this->getParam('db_where') ? ' WHERE '.$this->getParam('db_where') : '')
|
||||||
@@ -3687,20 +3687,31 @@ class e_tree_model extends e_front_model
|
|||||||
*/
|
*/
|
||||||
protected function countResults($sql)
|
protected function countResults($sql)
|
||||||
{
|
{
|
||||||
$total = $sql->foundRows();
|
$qry = $this->getParam('db_query');
|
||||||
$this->_total = is_int($total) ? $total : false; //requires SQL_CALC_FOUND_ROWS in query - see db handler
|
|
||||||
|
// @todo Move to $sql->foundRows();
|
||||||
|
|
||||||
|
$qry = str_replace('SQL_CALC_FOUND_ROWS', '', $qry); // Deprecated as of MySQL 8.0
|
||||||
|
|
||||||
if(false === $this->_total && $this->getModelTable() && !$this->getParam('nocount'))
|
if(false === $this->_total && $this->getModelTable() && !$this->getParam('nocount'))
|
||||||
{
|
{
|
||||||
//SQL_CALC_FOUND_ROWS not found in the query, do one more query
|
$countQry = preg_replace('/\s+LIMIT\s+\d+(\s*,\s*\d+)?\s*$/i', "", $qry);
|
||||||
// $this->_total = e107::getDb()->db_Count($this->getModelTable()); // fails with specific listQry
|
|
||||||
|
|
||||||
// Calculates correct total when using filters and search. //XXX Optimize.
|
$QRY = "SELECT COUNT(*) AS e_tree_total FROM ($countQry) AS grouped_rows";
|
||||||
$countQry = preg_replace('/(LIMIT ([\d,\s])*)$/', "", $this->getParam('db_query'));
|
|
||||||
|
|
||||||
$this->_total = e107::getDb()->gen($countQry);
|
$result = $sql->retrieve($QRY);
|
||||||
|
$total = $result['e_tree_total'] ?? 0;
|
||||||
|
|
||||||
|
if(E107_DEBUG_LEVEL == E107_DBG_SQLQUERIES)
|
||||||
|
{
|
||||||
|
e107::getMessage()->addDebug("Count Qry: ".str_replace('#',MPREFIX,$QRY));
|
||||||
|
e107::getMessage()->addDebug("Count Total: $total");
|
||||||
|
}
|
||||||
|
|
||||||
|
$this->_total = (int) $total;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return $this->_total;
|
return $this->_total;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -273,5 +273,5 @@
|
|||||||
"listQry": "",
|
"listQry": "",
|
||||||
"listQryBeforeFinal": ""
|
"listQryBeforeFinal": ""
|
||||||
},
|
},
|
||||||
"expected": "SELECT SQL_CALC_FOUND_ROWS `#links`.* FROM `#links` WHERE `#links`.link_category = '3' ORDER BY link_category,link_order ASC"
|
"expected": "SELECT `#links`.* FROM `#links` WHERE `#links`.link_category = '3' ORDER BY link_category,link_order ASC"
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user