diff --git a/src/Processor/Expression/BinaryOperatorEvaluator.php b/src/Processor/Expression/BinaryOperatorEvaluator.php index 2cca6e79..3770a951 100644 --- a/src/Processor/Expression/BinaryOperatorEvaluator.php +++ b/src/Processor/Expression/BinaryOperatorEvaluator.php @@ -226,8 +226,18 @@ public static function evaluate( case 'MOD': return \fmod((double) $left_number, (double) $right_number); case '/': + // Ensure division by 0 cannot occur and 0 divided by anything is also 0 + if ($right_number === 0 || $left_number === 0) { + return 0; + } + return $left_number / $right_number; case 'DIV': + // Ensure division by 0 cannot occur and 0 divided by anything is also 0 + if ($right_number === 0 || $left_number === 0) { + return 0; + } + return (int) ($left_number / $right_number); case '-': return $left_number - $right_number; diff --git a/src/Processor/SelectProcessor.php b/src/Processor/SelectProcessor.php index 53a3120d..56cf70da 100644 --- a/src/Processor/SelectProcessor.php +++ b/src/Processor/SelectProcessor.php @@ -301,7 +301,7 @@ function ($expr) { $parts = \explode(".%.", (string) $col); if ($expr->tableName() !== null) { - list($col_table_name, $col_name) = $parts; + [$col_table_name, $col_name] = $parts; if ($col_table_name == $expr->tableName()) { if (!\array_key_exists($col, $formatted_row)) { $formatted_row[$col_name] = $val; @@ -320,10 +320,16 @@ function ($expr) { continue; } + /** + * Evaluator case \Vimeo\MysqlEngine\Query\Expression\SubqueryExpression::class: + * should ensure the value of $val is never an array, and only the value of the + * column requested, but we'll leave this code just to make sure of that. + */ $val = Expression\Evaluator::evaluate($conn, $scope, $expr, $row, $group_result); $name = $expr->name; - if ($expr instanceof SubqueryExpression) { + if ($expr instanceof SubqueryExpression && \is_array($val)) { + // Assert is only used for debug, and will not stop code in a production env from running assert(\is_array($val), 'subquery results must be KeyedContainer'); if (\count($val) > 1) { throw new ProcessorException("Subquery returned more than one row"); @@ -477,7 +483,7 @@ private static function getSelectSchema( $parts = \explode(".", $column_id); if ($expr_table_name = $expr->tableName()) { - list($column_table_name) = $parts; + [$column_table_name] = $parts; if ($column_table_name === $expr_table_name) { $columns[$column_id] = $from_column;