Ответы пользователя по тегу MySQL
  • Как вставить данные из другой базы?

    @Akina
    Сетевой и системный админ, SQL-программист.
    И есть ли возможность у Mysql подключаться напрямую к другой базе на другом сервере?

    Да, есть. The FEDERATED Storage Engine.

    Как это сделать на PHP?

    На первом сервере выполнить SELECT .. INTO OUTFILE.
    Переместить полученный файл в место, доступное со второго сервера.
    На втором сервере выполнить LOAD DATA INFILE.
    Ответ написан
    Комментировать
  • Почему в phpmyadmin название таблиц не отображается с регистром букв?

    @Akina
    Сетевой и системный админ, SQL-программист.
    Регистрозависимость имён таблиц в MySQL определяется значением системной переменной lower_case_table_names. См. Identifier Case Sensitivity.

    Что же касается отображения имён в phpmyadmin - то это вопросы к нему, а не к MySQL. Можно попробовать выяснить экспериментально, как он реагирует на изменение значения указанной переменной, а также на явное квотирование имён бэктиками.
    Ответ написан
    3 комментария
  • Можно ли написать sql запрос на вывода последнего элемента?

    @Akina
    Сетевой и системный админ, SQL-программист.
    SELECT DISTINCT
           FIRST_VALUE(column_1) OVER (ORDER BY column_1 IS NULL, id DESC) column_1,
           FIRST_VALUE(column_2) OVER (ORDER BY column_2 IS NULL, id DESC) column_2
    FROM test;

    Если в "пустых" полях не NULL, а пустые строки, то соответственно
    SELECT DISTINCT
           FIRST_VALUE(column_1) OVER (ORDER BY column_1 = ' ', id DESC) column_1,
           FIRST_VALUE(column_2) OVER (ORDER BY column_2 = ' ', id DESC) column_2
    FROM test;

    fiddle

    Требуется MySQL версии 8+.
    Ответ написан
    Комментировать
  • Как удалить строку из 2-х таблиц одним запросом?

    @Akina
    Сетевой и системный админ, SQL-программист.
    что не так делаю?

    Полагаете, что запись с указанным ID существует.

    Если в table_1 такой записи нет - никаких удалений не будет, даже если во второй таблице есть такие записи.

    В общем случае для решения задачи одним запросом необходим FULL JOIN. Но увы, MySQL его не поддерживает. А потому в общем случае задача нерешаема.
    Ответ написан
    Комментировать
  • Как исправить ошибку индекса PRIMARY базы данных mysql bitrix24?

    @Akina
    Сетевой и системный админ, SQL-программист.
    Факт 1

    Сообщение об ошибке явно сгенерировано приложением, которое отлично знает, какой должна быть структура первичного индекса данной таблицы.

    Факт 2

    Я перенёс портал из облака в коробку


    Итого

    Факты свидетельствуют о том, что перенос был выполнен некорректно. Для исправления - удалите поле id, а затем создайте первичный индекс с указанными тремя полями.

    Для проверки - предварительно подключитесь к старой версии таблицы и проверьте, действительно ли в ней отсутствует автоинкрементное поле по фамилии id. А в качестве совсем бреда - сравните, какая СУБД (включая точную версию) на старом и на новом месте.
    Ответ написан
    Комментировать
  • Ошибка в mysql таблица не может быть создана в зарезервированном табличном пространстве mysql?

    @Akina
    Сетевой и системный админ, SQL-программист.
    mysql - это служебная БД. В ней как бы нежелательно создавать пользовательские таблицы.

    Если Вы хотите создать копию таблицы, делайте импорт в рабочую/временную базу данных. При этом убедитесь, что в дампе нет указания создавать таблицу именно в базе mysql (или явно отключите это при создании дампа).
    Ответ написан
    1 комментарий
  • Как выбрать ограниченное количество записей разного типа?

    @Akina
    Сетевой и системный админ, SQL-программист.
    3 эконома, 14 комфорта, 9 бизнеса, 4 премиум.


    Итого 3+14+9+4=30.

    Теперь нумеруем каждый тип по отдельности (используем целочисленное деление с остатком).

    Эконом - 1,2,3,31,32,33,61,62,63...
    Комфорт - 4,5,..,16,17,34,35,...
    Бизнес - 18,19,..25,26,48,49,...
    Премиум - 27,28,29,30,57,58,...

    И теперь сортируем при пагинации по этому номеру.

    Оно, конечно, всё равно поплывёт, когда какой-то тип закончится - но хоть не с самого начала.

    PS. Но вообще-то клиент, увидев на странице дикие скачки цен, и прыжки вверх-вниз между страницами, скорее всего закроет этот бред, чтобы мозг не поломался.
    Ответ написан
    Комментировать
  • Как выполнить backup базы данных mysql запросом?

    @Akina
    Сетевой и системный админ, SQL-программист.
    Очень теоретически можно организовать бэкап БД "одним запросом". И это будет запрос
    CALL stored_procedure(@datatbase_name);
    А вот в хранимой процедуре будет дофига запросов. Нужно будет из INFORMATION_SCHEMA получить список всех имеющихся в БД объектов и организовать копирование информации во внешний файл (причём для каждой таблицы придётся делать два файла - один со структурой, второй с данными). А ещё надо не забыть про процедуры, функции, триггеры... в общем, задачка весьма нетривиальная. Лучше даже не начинать.
    Ответ написан
    Комментировать
  • Как получить по лимиту данные из одной таблицы по разным критериям?

    @Akina
    Сетевой и системный админ, SQL-программист.
    WITH cte AS ( SELECT *, ROW_NUMBER() OVER (PARTITION BY id ORDER BY RAND()) rn
                  FROM ...
                  WHERE ID IN (1, 2, ..100) )
    SELECT *
    FROM cte
    WHERE rn <= 5
    Ответ написан
    2 комментария
  • Как исправить сортировку в MySql?

    @Akina
    Сетевой и системный админ, SQL-программист.
    У SUBSTRING_INDEX накладные расходы великоваты. Я бы использовал
    SELECT *
    FROM table_name
    ORDER BY 0 + SUBSTRING(column_name FROM 2)

    А для совсем ускорения, если такая сортировка используется часто, можно создать индекс по соотв. выражению, а то и generated column с соответствующим индексом.
    Ответ написан
    3 комментария
  • Как удалить в базе данных MYSQL все между двумя тегами?

    @Akina
    Сетевой и системный админ, SQL-программист.
    SELECT html, REGEXP_REPLACE(html, '<nav>[^<]*</nav>', '')
    FROM test;

    fiddle
    Ну и соответственно
    UPDATE test
    SET html = REGEXP_REPLACE(html, '<nav>[^<]*</nav>', '');
    Ответ написан
    5 комментариев