Table 11.11. Arithmetic Operators
Name | Description |
---|---|
DIV | Integer division |
/ | Division operator |
- | Minus operator |
% | Modulo operator |
+ | Addition operator |
* | Multiplication operator |
- | Change the sign of the argument |
The usual arithmetic operators are available. The result is determined according to the following rules:
In the case of
-
,+
, and*
, the result is calculated withBIGINT
(64-bit) precision if both operands are integers.If both operands are integers and any of them are unsigned, the result is an unsigned integer. For subtraction, if the
NO_UNSIGNED_SUBTRACTION
SQL mode is enabled, the result is signed even if any operand is unsigned.If any of the operands of a
+
,-
,/
,*
,%
is a real or string value, the precision of the result is the precision of the operand with the maximum precision.In division performed with
/
, the scale of the result when using two exact-value operands is the scale of the first operand plus the value of thediv_precision_increment
system variable (which is 4 by default). For example, the result of the expression5.05 / 0.014
has a scale of six decimal places (360.714286
).
These rules are applied for each operation, such that nested
calculations imply the precision of each component. Hence,
(14620 / 9432456) / (24250 / 9432456)
,
resolves first to (0.0014) / (0.0026)
, with
the final result having 8 decimal places
(0.60288653
).
Because of these rules and the way they are applied, care should be taken to ensure that components and subcomponents of a calculation use the appropriate level of precision. See Section 11.10, “Cast Functions and Operators”.
For information about handling of overflow in numeric expression evaluation, see Section 10.6, “Out-of-Range and Overflow Handling”.
Arithmetic operators apply to numbers. For other types of
values, alternative operations may be available. For example, to
add date values, use DATE_ADD()
;
see Section 11.7, “Date and Time Functions”.
Addition:
mysql>
SELECT 3+5;
-> 8Subtraction:
mysql>
SELECT 3-5;
-> -2Unary minus. This operator changes the sign of the operand.
mysql>
SELECT - 2;
-> -2Multiplication:
mysql>
SELECT 3*5;
-> 15 mysql>SELECT 18014398509481984*18014398509481984.0;
-> 324518553658426726783156020576256.0 mysql>SELECT 18014398509481984*18014398509481984;
-> 0The result of the last expression is incorrect because the result of the integer multiplication exceeds the 64-bit range of
BIGINT
calculations. (See Section 10.2, “Numeric Types”.)Division:
mysql>
SELECT 3/5;
-> 0.60Division by zero produces a
NULL
result:mysql>
SELECT 102/(1-1);
-> NULLA division is calculated with
BIGINT
arithmetic only if performed in a context where its result is converted to an integer.Integer division. Similar to
FLOOR()
, but is safe withBIGINT
values.As of MySQL 5.5.3, if either operand has a noninteger type, the operands are converted to
DECIMAL
and divided usingDECIMAL
arithmetic before converting the result toBIGINT
. If the result exceedsBIGINT
range, an error occurs. Before MySQL 5.5.3, incorrect results may occur for noninteger operands that exceedBIGINT
range.mysql>
SELECT 5 DIV 2;
-> 2Modulo operation. Returns the remainder of
N
divided byM
. For more information, see the description for theMOD()
function in Section 11.6.2, “Mathematical Functions”.