(истина, TRUE),
(ложь, FALSE) или
. Эти функции работают как с числами, так и со строками. Строки при
необходимости автоматически преобразуются в числа, а числа - в строки (как
в Perl).
, то и результат сравнения будет
. Справедливо для всех операторов кроме
.
Если оба аргумента в операторе сравнения являются строками, то они
сравниваются как строки.
Если оба аргумента - целые числа, то они сравниваются как целые числа.
Шестнадцатеричные величины, если они не сравниваются с числом,
трактуются как строки с двоичными данными.
, а второй аргумент - константа, то константа перед
выполнением сравнения преобразуется к типу
. Это сделано для
лучшей совместимости с ODBC.
Во всех других случаях аргументы сравниваются как действительные числа
с плавающей точкой.
По умолчанию сравнение строк производится без учета регистра символов с
использованием текущего набора символов (по умолчанию ISO-8859-1 Latin1,
который, к тому же, прекрасно подходит для английского языка).
Ниже приведены примеры, иллюстрирующие преобразование строк в числа для
операторов сравнения:
mysql> SELECT 1 = 0;
-> 0
mysql> SELECT '0' = 0;
-> 1
mysql> SELECT '0.0' = 0;
-> 1
mysql> SELECT '0.01' = 0;
-> 0
mysql> SELECT '.01' = 0.01;
-> 1
!=
mysql> SELECT '.01' <> '0.01';
-> 1
mysql> SELECT .01 <> '0.01';
-> 0
mysql> SELECT 'zapp' <> 'zappp';
-> 1
mysql> SELECT 0.1 <= 2;
-> 1
mysql> SELECT 1 <=> 1, NULL <=> NULL, 1 <=> NULL;
-> 1 1 0
Тест для определения, является величина равной
mysql> SELECT 1 IS NULL, 0 IS NULL, NULL IS NULL;
-> 0 0 1
mysql> SELECT 1 IS NOT NULL, 0 IS NOT NULL, NULL IS NOT NULL;
-> 1 1 0
Для того, чтобы MySQL хорошо работал с другими программами, обеспечивается
поддержка следующих дополнительных возможностей для функции
Можно найти последнюю вставленную строку, используя выражение:
.
See section
.
, используя выражение:
).
, то функция
,
в противном случае -
. Это эквивалентно выражению (
), в котором все аргументы представлены одним и тем же типом данных.
Способ выполнения сравнения определяется первым аргументом (
,
, а величины
являются константами, то последние
приводятся к тому же формату, что и столбец.
является независимым от регистра символов строковым
выражением, то производится сравнение строк без учета регистра.
является зависимым от регистра символов строковым
выражением, то производится сравнение строк с учетом регистра.
представляет собой целочисленное выражение, то выполняется
сравнение целых чисел.
Во всех остальных случаях производится сравнение аргументов как
действительных чисел с плавающей точкой.
.
expr IN (value,...)
, если выражение expr равно любой величине из списка
,
иначе -
. Если все величины - константы, то они оцениваются в
соответствии с типом выражения expr и сортируются. Поиск элемента в
этом случае производится методом логического поиска. Это означает, что
функция
является очень быстрой, если список значений
состоит
полностью из констант. Если expr является зависимым от регистра
строковым выражением, то сравнение строк производится с учетом
регистра:
mysql> SELECT 2 IN (0,3,5,'wefwf');
-> 0
mysql> SELECT 'wefwf' IN (0,3,5,'wefwf');
-> 1
expr NOT IN (value,...)
NOT (expr IN (value,...))
.
, то
, в противном случае -
!
Возвращает первый в списке элемент со значением, не равным
mysql> SELECT COALESCE(NULL,1);
-> 1
mysql> SELECT COALESCE(NULL,NULL,NULL);
-> NULL
INTERVAL(N,N1,N2,N3,...)
, если
, и
, если
, и так далее. Все аргументы
трактуются как целые числа. Для корректной работы этой функции необходимо
условие
N1 < N2 < N3 < ... < Nn
. Это обусловлено тем, что используется
логический поиск (очень быстрый):
mysql> SELECT INTERVAL(23, 1, 15, 17, 30, 44, 200);
-> 3
mysql> SELECT INTERVAL(10, 1, 10, 100, 1000);
-> 2
mysql> SELECT INTERVAL(22, 23, 30, 44, 200);
-> 0
=,
, ..., но не
), то конечный пробел
игнорируется.