Ошибка mysql error the error returned was

$db->query("INSERT INTO `".USERPREFIX."_users_status` (`name`, `user_status`) VALUES ('{$sql}', '{$member_id['name']}'");

Когда выполняю запрос выводит такую ошибку

Error Number: 1064 The Error returned was: You have an error in your
SQL syntax; check the manual that corresponds to your MySQL server
version for the right syntax to use near » at line 1

Suvitruf - Andrei Apanasik's user avatar

задан 21 июн 2013 в 16:10

Xcho's user avatar

В ошибке по сути всё изложено «Номер ошибки: 1064 Обнаружена ошибка: У вас ошибка в запросе, проверить документацию по используемой версии MySQL на предмет корректного синтаксиса использовать вблизи» в строке 1″

Т.е. в 1 строке своего фала внимательнее посмотри код

ответ дан 21 июн 2013 в 16:35

handbat0's user avatar

handbat0handbat0

2041 золотой знак5 серебряных знаков16 бронзовых знаков

1

Вроде закрывающей ) в конце не хватает

ответ дан 21 июн 2013 в 16:46

Михаил М's user avatar

Михаил ММихаил М

2,0151 золотой знак11 серебряных знаков16 бронзовых знаков

Дата: 25.11.2013

Автор: Василий Лукьянчиков , vl (at) sqlinfo (dot) ru

Статья ориентирована на новичков. В ней объясняется, что означает ошибка сервера MySQL №1064, рассматриваются типичные ситуации и причины возникновения этой ошибки, а также даются рекомендации по исправлению.

Рассмотрим простейший пример.

SELECT mid, time, title, artist, download, view_count, rating, vote_num FROM dle_mservice WHERE category = ‘1’ AND approve = ‘1’ ORDER BY time DESC LIMIT -10,10;
ERROR 1064 (42000): You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near ‘-10,10’ at line 1

Сервер MySQL сообщает, что в первой строке нашего SQL запроса имеется синтаксическая ошибка, и в одинарных кавычках цитирует часть запроса с того места где начинается ошибка. Это очень полезное свойство, так как позволяет сразу определить место, которое сервер счел ошибочным. В данном случае это ‘-10,10’, ошибка возникает из-за того, что параметр LIMIT не может быть отрицательным числом.

Однако, бывает и так, что цитируемый кусок запроса не содержит синтаксической ошибки. Это означает, что данная часть запроса находится не на своем месте из-за чего весь запрос становится синтаксически неверным. Например, отсутствует разделитель между двумя запросами, пропущен кусок запроса, невидимый символ в дампе и т.д. Неудобством таких ситуаций является то, что сообщение об ошибке не содержит исходный запрос.
Действия по исправлению зависят от контекста возникновения ошибки. Таковых всего 3:

1. Запрос в редакторе.

Самый простейший случай — вы пишите свой запрос в редакторе. Если причина не опечатка, то:

  • Смотреть в документации синтаксис команды для вашей версии сервера MySQL.

    Обратите внимание: речь идет о версии сервера MySQL, а не клиента (phpmyadmin, workbench и т.д.). Версию сервера можно узнать выполнив команду select version();

  • В MySQL допускается использование ключевых слов в качестве имен столбцов/таблиц, но при этом их необходимо заключать в обратные кавычки (там где буква ё на клавиатуре).
    Пример:

    select order from test;
    ERROR 1064 (42000): You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near ‘order from test’ at line 1
    MariaDB [test]> select `order` from test;
    +——-+
    | order |
    +——-+
    |  NULL |
    +——-+

  • По умолчанию ; разделяет команды. Если же нужно выполнить набор из нескольких инструкций как одну команду (например, при создании процедур, фунуций, триггеров), то в зависимости от используемого клиента может потребоваться переопределить разделитель с помощью DELIMITER, иначе интерпретация команды остановится на первой ; и будет ошибка синтаксиса. Пример:

    delimiter //
    create procedure test()
    begin
    set @a=1;
    select @a;
    end//

    Обратите внимание: DELIMITER это команда консольного клиента mysql, необходимость его использования зависит от того как вы передаете команду серверу. Например,:

    • mysql_query() выполняет содержимое как одну команду, добавление delimiter приведет к error 1064 с цитатой, начинающейся со слова delimiter
    • phpmyadmin удаляет слово delimiter из-за чего возникает error 1064 с цитатой, начинающейся с переопределенного разделителя
    • в MysqlQueryBrowser напротив необходимо использовать delimiter.

2. Перенос базы на другой сервер.

У вас есть дамп (т.е. файл с расширением .sql) и при попытке его импортировать вы получаете ошибку 1064. Причины:

  • В различных версиях набор ключевых слов и синтаксис может немного отличаться. Наиболее распространенный случай: команда create table, в которой ключевое слово type было заменено на engine. Например, если вы получаете ошибку:

    You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near ‘TYPE=MyISAM CHARACTER SET `utf8`’ at line 29

    Это означает, что вы переносите базу в пятую версию сервера MySQL, в котором ключевое слово TYPE не поддерживается и его нужно заменить на ENGINE.

    Редко бываю случаи, когда перенос идет на старый (~3.23) сервер, который кодировки не поддерживает. Тогда ошибка будет иметь вид:

    #1064 — You have an error in your SQL syntax near ‘DEFAULT CHARACTER SET cp1251 COLLATE cp1251_general_ci’ at line 1

    Такое может произойти, если вы переносите базу с хостинга на локальный комп, где стоит древняя версия MySQL. Лучшим решением в данном случае будет не править дамп, а обновить MySQL.

  • Часто проблемы вызваны тем, что дамп делается неродными средствами MySQL (например, phpmyadmin) из-за чего в нем могут быть BOM-маркер, собственный синтаксис комментариев, завершения команды и т.д. Кроме того при использовании того же phpmyadmin возможна ситуация при которой из-за ограничения апача на размер передаваемого файла команда будет обрезана, что приведет к ошибке 1064.
    Например, если вы получаете ошибку:

    #1064 — You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near ‘
    CREATE TABLE `jos_banner` (
      `bid` int(11) NOT NULL auto_increment,
      `ci‘ at line 1

    Значит ваш дамп содержит BOM-маркер. Это три байта в начале файла, помогающие программе определить что данный файл сохранен в кодировке UTF-8. Проблема в том, что MySQL пытается интерпретировать их как команду из-за чего возникает ошибка синтаксиса. Нужно открыть дамп в текстовом редакторе (например, Notepad++) и сохранить без BOM.

    Для избежания подобных проблем при создании дампа и его импорте лучше пользоваться родными средствами MySQL, см http://sqlinfo.ru/forum/viewtopic.php?id=583

3. Некорректная работа сайта.

Если во время работы сайта появляются ошибки синтаксиса, то, как правило, причина в установке вами сомнительных модулей к вашей cms. Лучшее решение — отказаться от их использования. Еще лучше предварительно проверять их работу на резервной копии.

Пример. Движок dle 7.2, поставили модуль ,вроде бы все Ок, но:

MySQL Error!
————————
The Error returned was:
You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near ‘AND approve=’1‘ AND date < ‘2008-10-04 04:34:25‘ LIMIT 5’ at line 1

Error Number:
1064
SELECT id, title, date, category, alt_name, flag FROM dle_post WHERE MATCH (title, short_story, full_story, xfields, title) AGAINST (‘Приобретение и оплата скрипта ‘) AND id !=  AND approve=‘1’ AND date < ‘2008-10-04 04:34:25’ LIMIT 5

В данном примере мы видим, что причина ошибки в отсутствии значения после «id != «

Обратите внимание: из процитированного сервером MySQL куска запроса причина ошибки не ясна. Если ваша CMS не показывает весь запрос целиком, то нужно в скриптах найти место где выполняется данный запрос и вывести его на экран командой echo.

Кусок кода, который отвечает за данный запрос это

$db->query («SELECT id, title, date, category, alt_name, flag FROM « . PREFIX . «_post WHERE MATCH (title, short_story, full_story, xfields, title) AGAINST (‘$body’) AND id != «.$row[‘id’].» AND approve=’1′».$where_date.» LIMIT «.$config[‘related_number’]);

Далее можно искать откуда взялась переменная $row и почему в ней нет элемента ‘id’ и вносить исправления, но лучше отказаться от использования такого модуля (неизвестно сколько сюрпризов он еще принесет).

P.S. Если после прочтения статьи ваш вопрос с MySQL Error 1064 остался нерешенным, то задавайте его на форуме SQLinfo

Дата публикации: 25.11.2013

© Все права на данную статью принадлежат порталу SQLInfo.ru. Перепечатка в интернет-изданиях разрешается только с указанием автора и прямой ссылки на оригинальную статью. Перепечатка в бумажных изданиях допускается только с разрешения редакции.

ПафНутиЙ, Привет. я адаптировал его немного под DLE 16
Но возник вопрос как, сделать очистку кэша адекватной?) такое чувство что она не очищается

для DLE 16.0 поправил тут, с 33 строчки

if ($show_query) {
    $total_time_query = $db->query_list;
    if (is_array($total_time_query)) {
        for ($i = 0; $i < count($total_time_query); $i++) {
            $color = ($total_time_query[$i]['time'] > 0.01) ? 'red' : 'green';
            $rounded_time = sprintf("%.8f", $total_time_query[$i]['time']);
            $time_query .= "<p><span style='color:".$color."'>".$rounded_time."</span> сек. - [ ".htmlspecialchars($total_time_query[$i]['query'])." ]</p>";
        }
    }
}

и тут начиная с 159 строчки:

if (!$nolog) {
		$base_path = $site_root . '/uploads/stat_log.html';
		$statfile = fopen($base_path, 'r');
		if ($statfile) {
			$fileSize = round(filesize($base_path) / 1024, 2);
			$logContent = fgets($statfile);
			fclose($statfile);
	
			$showstat .= "<a id='log-link' href='".$config['http_home_url']."uploads/stat_log.html' target='_blank' title='Смотреть лог. Лимит ".$size."Кб,  сейчас: ".$logContent.$fileSize."Кб'></a>";
		}
	}

Время от времени сайт на DLE падает выдавая ошибку My SQL Error, 

MySQL error in file: /engine/classes/mysql.php at line 52

Error Number: 1

The Error returned was:
Can’t connect to local MySQL server through socket ‘/var/run/mysqld/mysqld.sock’ (2)

SQL query:

Поискав инфу и почитав единственное, что удалось найти — это в настройках движка отключение выдачи предупреждений, но мне не удалось это сделать. 

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

1. Перевел сайт в offline

2. Обновите все файлы из папки /upload/ вашего архива (за исключением /templates/)

3. зашел по ссылке http://website.com/upgrade/index.php

4. Обновление скрипта до актуальной версии 12.0 было успешно завершено. Удалите папку /upgrade/ с вашего сервера. далее нажал продолжить.

5. Открывается сайт и всё.

теперь ошибка в ПУ при редактировании новости

MySQL Error!

MySQL error in file: /engine/inc/editnews.php at line 186

Error Number: 1054

The Error returned was:
Unknown column ‘e.need_pass’ in ‘field list’

SQL query:

SELECT p.id, p.date, p.title, p.category, p.autor, p.alt_name, p.comm_num, p.approve, p.fixed, e.news_read, e.votes, e.user_id, e.need_pass FROM dle_post p LEFT JOIN dle_post_extras e ON (p.id=e.news_id) ORDER BY fixed desc, approve asc, date desc LIMIT 0,50


Изменено 12 ноября 2017 пользователем 47rus

Понравилась статья? Поделить с друзьями:
  • Ошибка mysql duplicate entry 1 for key primary
  • Ошибка mysql access denied for user root localhost
  • Ошибка mysql 1146 что это
  • Ошибка mysql 1114 что делать
  • Ошибка mysql 1046 no database selected