mirror of
				https://github.com/e107inc/e107.git
				synced 2025-10-25 19:56:49 +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) | ||||||
|  | 			if(E107_DEBUG_LEVEL == E107_DBG_SQLQUERIES) | ||||||
|  | 			{ | ||||||
| 				e107::getMessage()->addDebug('<pre>' . $jsonDebugInfo . '</pre>'); | 				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