Справочное руководство по MySQL версии 4.1.1-alpha


1.9.3 Расширения MySQL к ANSI SQL92 - часть 3


  • Команды ANALYZE TABLE, CHECK TABLE, OPTIMIZE TABLE и REPAIR TABLE.

  • Команда SHOW (see section 4.5.6 Синтаксис команды SHOW).

  • Строки могут быть заключены в кавычки с помощью или `"', или `'', но не просто `''.

  • Использование символа экранирования `\'.

  • Команда SET (see section 5.5.6 Синтаксис команды SET).

  • Нет необходимости называть имена всех выбранных столбцов в части GROUP BY. Это дает лучшую производительность для некоторых очень специфических, но вполне нормальных запросов (see section 6.3.7 Функции, используемые в операторах GROUP BY).

  • Можно указывать ASC и DESC с GROUP BY.

  • Чтобы упростить работу для пользователей, привыкших к иным условиям среды SQL, в сервере MySQL поддерживаются псевдонимы для многих функций. Например, для всех строковых функций поддерживается синтаксис как ANSI SQL, так и ODBC.

  • Сервер MySQL понимает операторы || и && для обозначения логических ИЛИ (OR) и И (AND), как это принято в языке программирования C. В сервере MySQL || и ИЛИ (OR) являются синонимами, так же, как && и И (AND). Благодаря этому удобному синтаксису, в сервере MySQL не поддерживается оператор ANSI SQL || для конкатенации строк: вместо него используется функция CONCAT(). Поскольку функция CONCAT() принимает любое количество аргументов, то в сервере MySQL можно легко модифицировать использование оператора ||.

  • CREATE DATABASE или DROP DATABASE (see section 6.5.1 Синтаксис оператора CREATE DATABASE).

  • Оператор % является синонимом для MOD(). Т.е. N % M эквивалентно MOD(N,M). Оператор % поддерживается для программистов на C и для совместимости с PostgreSQL.

  • Операторы =, <>, ,, >=,>, , >>, , AND, OR или LIKE могут использоваться при сравнении столбцов слева от FROM в командах SELECT. Например:

    mysql> SELECT col1=1 AND col2=2 FROM tbl_name;

  • Функция LAST_INSERT_ID() (see section 8.4.3.31 mysql_insert_id()).

  • Операторы REGEXP и NOT REGEXP расширенных регулярных выражений.

  • CONCAT() или CHAR() с одним аргументом или более чем с двумя аргументами (в сервере MySQL эти функции могут принимать любое количество аргументов).

  • Функции BIT_COUNT(), CASE, ELT(), FROM_DAYS(), FORMAT(), IF(), PASSWORD(), ENCRYPT(), MD5(), ENCODE(), DECODE(), PERIOD_ADD(), PERIOD_DIFF(), TO_DAYS() или WEEKDAY().

  • Использование функции TRIM() для усечения подстрок. В ANSI SQL поддерживается только удаление единичных символов.

  • Операция GROUP BY для функций STD(), BIT_OR() и BIT_AND().

  • Использование REPLACE вместо DELETE + INSERT (see section 6.4.8 Синтаксис оператора REPLACE).

  • Команды FLUSH, RESET и DO.

  • Возможность устанавливать переменные в команде с помощью :=:

    SELECT @a:=SUM(total),@b=COUNT(*),@a/@b AS avg FROM test_table; SELECT @t1:=(@t2:=1)+@t3:=4,@t1,@t2,@t3;




    Начало  Назад  Вперед



    Книжный магазин