English | 简体中文 | 繁體中文 | Русский язык | Français | Español | Português | Deutsch | 日本語 | 한국어 | Italiano | بالعربية

Операторы MySQL

В этой главе мы основательно介绍 операторы MySQL и приоритет их выполнения. MySQL主要有 следующие операторы:

  • Арифметические операторы

  • Сравнительные операторы

  • |                     0 |

  • Битовые операторы

Арифметические операторы

Арифметические операторы, поддерживаемые MySQL включают:

ОператорыЗначение
+Добавление
-Сокращение
*Умножение
/ или DIVДеление
% или MODОставшаяся часть

В арифметических операциях и операциях модуля, если делитель равен 0, это будет незаконный делитель, результат будет NULL.

1、加

mysql> select 1+2;
+-----+
| 1+2 |
+-----+
|   3 |
+-----+

2、减

mysql> select 1-2;
+-----+
| 1-2 |
+-----+
|  -1 |
+-----+

3、乘

mysql> select 2*3;
+-----+
| 2*3 |
+-----+
|   6 |
+-----+

4、деление

mysql> select 2/3;
+--------+
| 2/3          |
+--------+
| 0.6667 |
+--------+

5、количество

mysql> select 10 DIV 4;
+----------+
| 10 DIV 4 |
+----------+
|                                 2 |
+----------+

6、остаток от деления

mysql> select 10 MOD 4;
+----------+
| 10 MOD 4 |
+----------+
|                                 2 |
+----------+

Сравнительные операторы

Условные предложения в предложениях SELECT часто используют сравнительные операторы. С их помощью можно определить, какие записи в таблице соответствуют условиям. Если результат сравнения истинен, то возвращается 1, если ложно, то возвращается 0, если результат неопределен, то возвращается NULL.

СимволОписаниеПримечание
=равно
<>, !=не равно
>больше
<меньше
<=меньше или равно
>=больше или равно
BETWEENмежду двумя значениями>=min && <=max
NOT BETWEENне между двумя значениями
INв наборе
NOT INне в наборе
<=>Точное сравнение двух NULL-значений на равенствоКогда оба операнда равны NULL, результат равен 1; когда один операнд равен NULL, результат равен 0
LIKEнеопределенное совпадение
REGEXP или RLIKEСовпадение регулярного выражения
IS NULLпусто
IS NOT NULLне пусто

1、равно

mysql> select 2=3;
+-----+
| 2=3 |
+-----+
|   0 |
+-----+
mysql> select NULL = NULL;
+-------------+
| NULL = NULL |
+-------------+
|                                 NULL |
+-------------+

2、не равно

mysql> select 2<>3;
+------+
| 2<>3 |
+------+
|    1 |
+------+

3、безопасное равенство

Разница между = и <=> заключается в том, что когда оба операнда равны NULL, результат равен 1, а не NULL, а когда один операнд равен NULL, результат равен 0, а не NULL.

mysql> select 2<=>3;
+-------+
| 2<=>3 |
+-------+
|     0 |
+-------+
mysql> select null=null;
+-----------+
| null=null |
+-----------+
|                     NULL |
+-----------+
        
mysql> select null<=>null;
+-------------+
| null<=>null |
+-------------+
|                                 1 |
+-------------+

4、меньше

mysql> select 2<3;
+-----+
| 2<3 |
+-----+
|   1 |
+-----+

5、меньше или равно

mysql> select 2<=3;
+------+
| 2<=3 |
+------+
|    1 |
+------+

6、больше

mysql> select 2>3;
+-----+
| 2>3 |
+-----+
|   0 |
+-----+

7、大于等于

mysql> select 2>=3;
+------+
| 2>=3 |
+------+
|    0 |
+------+

8、BETWEEN

mysql> select 5 between 1 and 10;
+--------------------+
| 5 between 1 and 10 |
+--------------------+
|                  1 |
+--------------------+

9、IN

mysql> select 5 in (1,2,3,4,5);
+------------------+
| 5 in (1,2,3,4,5) |
+------------------+
|                1 |
+------------------+

10、NOT IN

mysql> select 5 not in (1,2,3,4,5);
+----------------------+
| 5 not in (1,2,3,4,5) |
+----------------------+
|                    0 |
+----------------------+

11、IS NULL

mysql> select null is NULL;
+--------------+
| null is NULL |
+--------------+
|            1 |
+--------------+
mysql> select 'a' is NULL;
+-------------+
| 'a' is NULL |
+-------------+
|           0 |
+-------------+

12、IS NOT NULL

mysql> select null IS NOT NULL;
+------------------+
| null IS NOT NULL |
+------------------+
|                0 |
+------------------+
        
mysql> select 'a' IS NOT NULL;
+-----------------+
| 'a' IS NOT NULL |
+-----------------+
|               1 |
+-----------------+

13、LIKE

mysql> select '12345' like '12%';
+--------------------+
| '12345' like '12%' |
+--------------------+
|                  1 |
+--------------------+
mysql> select '12345' like '12_';
+--------------------+
| '12345' like '12_' |
+--------------------+
|                  0 |
+--------------------+

14、REGEXP

mysql> select 'beijing' REGEXP 'jing';
|                     1 |
| 'beijing' REGEXP 'jing' |
|                     1 |
| 'beijing' REGEXP 'jing' |
|                     1 |
+-------------------------+
+-----------------------+
mysql> select 'beijing' REGEXP 'xi';
+-----------------------+
| 'beijing' REGEXP 'xi' |
+-----------------------+

|                     0 |

Логические операторы

ОператорыЗначение
Логические операторы используются для определения истинности или ложности выражения. Если выражение истинно, результат возвращается 1. Если выражение ложно, результат возвращается 0.Логический NOT или !
ANDЛогический AND
ORЛогический OR
XORЛогический XOR

1、AND

mysql> select 2 and 0;
+---------+
| 2 and 0 |
+---------+
|       0 |
+---------+
        
mysql> select 2 and 1;   
+---------+     
| 2 and 1 |      
+---------+      
|       1 |      
+---------+

2、OR

mysql> select 2 or 0;
+--------+
| 2 or 0 |
+--------+
|      1 |
+--------+
mysql> select 2 or 1;
+--------+
| 2 or 1 |
+--------+
|      1 |
+--------+
mysql> select 0 or 0;
+--------+
| 0 or 0 |
+--------+
|      0 |
+--------+
mysql> select 1 || 0;
+--------+
| 1 || 0 |
+--------+
|      1 |
+--------+

3、NOT

mysql> select not 1;
+-------+
| not 1 |
+-------+
|     0 |
+-------+
mysql> select !0;
+----+
| !0 |
+----+
|  1 |
+----+

4、XOR

mysql> select 1 xor 1;
+---------+
| 1 xor 1 |
+---------+
|       0 |
+---------+
mysql> select 0 xor 0;
+---------+
| 0 xor 0 |
+---------+
|       0 |
+---------+
mysql> select 1 xor 0;
+---------+
| 1 xor 0 |
+---------+
|       1 |
+---------+
mysql> select null or 1;
+-----------+
| null or 1 |
+-----------+
|         1 |
+-----------+
mysql> select 1 ^ 0;
+-------+
| 1 ^ 0 |
+-------+
|     1 |
+-------+

Битовые операторы

Битовые операторы выполняют вычисления над двоичными числами. Битовые операции сначала преобразуют операнды в двоичные числа, выполняют битовые операции, а затем преобразуют результат вычисления из двоичного числа в десятичное.

ОператорыЗначение
&И битов
|ИЛИ битов
^XOR битов
!Инверсия
<<Сдвиг влево
>>Сдвиг вправо

1、И битов

mysql> select 3&5;
+-----+
| 3&5 |
+-----+
|   1 |
+-----+

2、ИЛИ битов

mysql> select 3|5;
+-----+
| 3|5 |
+-----+
|   7 |
+-----+

3、XOR битов

mysql> select 3^5;
+-----+
| 3^5 |
+-----+
|   6 |
+-----+

4、Инверсия битов

mysql> select ~18446744073709551612;
+-----------------------+
| ~18446744073709551612 |
+-----------------------+
|                     3 |
+-----------------------+

5、Сдвиг битов вправо

mysql> select 3>>1;
+------+
| 3>>1 |
+------+
|    1 |
+------+

6、Сдвиг битов влево

mysql> select 3<<1;
+------+
| 3<<1 |
+------+
|    6 |
+------+

Приоритет операторов

Низший приоритет имеют: :=.

Наивысший приоритет имеют: !, BINARY, COLLATE.