it-swarm.com.ru

Ошибка MySQl # 1064

Я продолжаю получать эту ошибку:

MySQL сказал: # 1064 - У вас есть ошибка в вашем синтаксисе SQL; проверьте руководство это соответствует вашему серверу MySQL версия для правильного использования синтаксиса около 'INSERT INTO books.book (isbn10, isbn13, название, издание, имя_ф_ра_ автора ,_м_ав_и_ в строке 15

с этим запросом:

USE books;

DROP TABLE IF EXISTS book;


    CREATE TABLE `books`.`book`(
    `book_id` INT UNSIGNED NOT NULL AUTO_INCREMENT PRIMARY KEY,
    `isbn10` VARCHAR(15) NOT NULL,
    `isbn13` VARCHAR(15) NOT NULL,
    `title` VARCHAR(50) NOT NULL,
    `edition` VARCHAR(50) NOT NULL,
    `author_f_name` VARCHAR(50) NOT NULL,
    `author_m_name` VARCHAR(50) NOT NULL,
    `author_l_name` VARCHAR(50) NOT NULL,
    `cond` ENUM('as new','very good','good','fair','poor') NOT NULL,
    `price` DECIMAL(8,2) NOT NULL,
    `genre` VARCHAR(50) NOT NULL,
    `quantity` INT NOT NULL)

    INSERT INTO books.book(isbn10,isbn13,title,edition,author_f_name,author_m_name,author_l_name,cond,price,genre,quantity)** 
    VALUES ('0136061699','978-0136061694','Software Engineering: Theory and Practice','4','Shari','Lawrence','Pfleeger','very good','50','Computing','2');

Есть идеи, в чем проблема?

14
Anthony

может быть, вы забыли добавить «;» после этой строки кода:

`quantity` INT NOT NULL)
25
Puaka

В моем случае у меня была та же самая ошибка, и позже я узнал, что ' условие ' является зарезервированным ключевым словом mysql, и я использовал это как имя поля.

3
Keval Kothari

Сначала необходимо добавить точку с запятой (;) после quantity INT NOT NULL), Затем удалить ** из ,genre,quantity)**., Чтобы вставить значение с числовым типом данных, например int, decimal, float и т.д. Вам не нужно добавлять одиночные цитаты.

0
Exp3rt

Иногда, когда ваша таблица имеет имя, похожее на имя базы данных, вы должны использовать галочку назад. так что вместо:

INSERT INTO books.book(field1, field2) VALUES ('value1', 'value2');

Вы должны иметь это: 

INSERT INTO `books`.`book`(`field1`, `field2`) VALUES ('value1', 'value2');
0
Joseph Rex