MySQL сначала оценивают интерпретируемый как columnname

Используя JDBC, я пытаюсь выполнить следующий SQL-оператор:

INSERT INTO meta (title, hlcount, textcount, imgcount, linkcount) VALUES (SomeString,6,4794,1,76)

Но это возвращает errormessage

Неизвестная колонка 'SomeString' в 'cписке полей'

Таким образом, кажется, что первая из ценностей интерпретируется как колонка, как это?

Уже проверенный структура таблицы, возможно я просто туннелированный на этом, но я просто, может казаться, не нахожу причину для этой проблемы.

1
Попробуйте "SomeString" вместо SomeString.
добавлено автор Peter Rader, источник
Последовательность в переменных кавычек без кавычек:)
добавлено автор Sanyam Goel, источник
Последовательность в переменных кавычек без кавычек:)
добавлено автор Sanyam Goel, источник
вы добавляли кавычки к своей последовательности?
добавлено автор duffy356, источник
вы добавляли кавычки к своей последовательности?
добавлено автор duffy356, источник
попробуйте ' someString' вместо этого
добавлено автор justMe, источник
попробуйте ' someString' вместо этого
добавлено автор justMe, источник

10 ответы

Таким образом, кажется, что первая из ценностей интерпретируется как колонка, как это?

Поскольку у вас есть он так же, как SomeString , вместо как текст стоимость , такая как 'SomeString' . Это, как SQL работает - и это - как нормальный код работает также, действительно. Если вы имели:

String foo = bar;

вы ожидали бы, что, чтобы попытаться скопировать ценность названной переменной бар , не так ли? Если бы вы имели в виду ряд из трех знаков, b, a, r, вы использовали бы:

String foo = "bar";

Это находится все равно в SQL.

Однако принятие этого SQL создается от действительных значений, необходимо использовать PreparedStatement с параметрами так или иначе:

String sql = "INSERT INTO meta (title, hlcount, textcount, imgcount, linkcount)"
             + " VALUES (?, ?, ?, ?, ?)";
PreparedStatement pst = conn.prepareStatement(sql);
pst.setString(1, "SomeString");
pst.setInt(2, 6);
// etc

Тем путем вы избежите атак с использованием кода на SQL и проблем преобразования строк (например, для дат). Это также держит вашего уборщика SQL, отделяя код от данных.

5
добавлено

Таким образом, кажется, что первая из ценностей интерпретируется как колонка, как это?

Поскольку у вас есть он так же, как SomeString , вместо как текст стоимость , такая как 'SomeString' . Это, как SQL работает - и это - как нормальный код работает также, действительно. Если вы имели:

String foo = bar;

вы ожидали бы, что, чтобы попытаться скопировать ценность названной переменной бар , не так ли? Если бы вы имели в виду ряд из трех знаков, b, a, r, вы использовали бы:

String foo = "bar";

Это находится все равно в SQL.

Однако принятие этого SQL создается от действительных значений, необходимо использовать PreparedStatement с параметрами так или иначе:

String sql = "INSERT INTO meta (title, hlcount, textcount, imgcount, linkcount)"
             + " VALUES (?, ?, ?, ?, ?)";
PreparedStatement pst = conn.prepareStatement(sql);
pst.setString(1, "SomeString");
pst.setInt(2, 6);
// etc

Тем путем вы избежите атак с использованием кода на SQL и проблем преобразования строк (например, для дат). Это также держит вашего уборщика SQL, отделяя код от данных.

5
добавлено

Последовательность должна быть в одинарных кавычках ('').

INSERT INTO meta (title, hlcount, textcount, imgcount, linkcount) VALUES ('SomeString',6,4794,1,76)
2
добавлено

Последовательность должна быть в одинарных кавычках ('').

INSERT INTO meta (title, hlcount, textcount, imgcount, linkcount) VALUES ('SomeString',6,4794,1,76)
2
добавлено

когда когда-либо вы вставляете дату или натягиваете ценности, необходимо приложить к

любой '' (одинарные кавычки) [всегда использует это]

или, "" (назад помечают характер) [не всегда]

INSERT INTO meta (название, hlcount, textcount, imgcount, linkcount) ЦЕННОСТИ ('SomeString', 6,4794,1,76)

или

INSERT INTO meta (название, hlcount, textcount, imgcount, linkcount) ЦЕННОСТИ ("SomeString", 6,4794,1,76)

1
добавлено

когда когда-либо вы вставляете дату или натягиваете ценности, необходимо приложить к

любой '' (одинарные кавычки) [всегда использует это]

или, "" (назад помечают характер) [не всегда]

INSERT INTO meta (название, hlcount, textcount, imgcount, linkcount) ЦЕННОСТИ ('SomeString', 6,4794,1,76)

или

INSERT INTO meta (название, hlcount, textcount, imgcount, linkcount) ЦЕННОСТИ ("SomeString", 6,4794,1,76)

1
добавлено

Поместите кавычки вокруг SomeString.

INSERT INTO meta 
  (title, hlcount, textcount, imgcount, linkcount) 
VALUES ('SomeString',6,4794,1,76)

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

1
добавлено

Поместите кавычки вокруг SomeString.

INSERT INTO meta 
  (title, hlcount, textcount, imgcount, linkcount) 
VALUES ('SomeString',6,4794,1,76)

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

1
добавлено

необходимо использовать одинарные кавычки 'Somestring'.

 INSERT INTO meta (title, hlcount, textcount, imgcount, linkcount) VALUES  ('SomeString',6,4794,1,76)  

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

1
добавлено

необходимо использовать одинарные кавычки 'Somestring'.

 INSERT INTO meta (title, hlcount, textcount, imgcount, linkcount) VALUES  ('SomeString',6,4794,1,76)  

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

1
добавлено
pro.jvm
pro.jvm
3 503 участник(ов)

Сообщество разработчиков Java Scala Kotlin Groovy Clojure Чат для нач-их: @javastart Наш сайт: projvm.com projvm.ru Наш канал: @proJVM Вакансии: @jvmjobs Конфы: @jvmconf

Java & Co
Java & Co
2 370 участник(ов)

Можно обсуждать с матом и без всё, что касается жабы, вплоть до холиваров. НЕ ИМЕЕТ ОТНОШЕНИЯ К САЙТУ JAVARUSH.RU ПРАВИЛА - https://t.me/javarush/75723 Вакансии сюда - https://telegram.me/joinchat/B7IzvUCnfo6d8t3yIxKguQ По вопросам - @thedude

learn.java
learn.java
1 888 участник(ов)

Чат для начинающих и не только Статистика: https://combot.org/chat/-1001083535868 Основной чат - @jvmchat

SqlCom.ru - Стиль жизни SQL
SqlCom.ru - Стиль жизни SQL
908 участник(ов)

Правила чата - https://t.me/sqlcom/88269 @sqlcom - основной канал (только MS SQL) @sql_ninja - второй канал (SQL вопросы начального уровня и свободное общение) @Gopnegbot - Викторина по SQL Server (наберите в привате /quiz). Предложения в @sql_ninja

SQL_Ninja
SQL_Ninja
340 участник(ов)

Правила чата - https://t.me/sqlcom/88269 @sqlcom - основной канал (только SQL) @sql_ninja - второй канал (SQL вопросы начального уровня и свободное общение) @Gopnegbot - Викторина по SQL Server (наберите в привате /quiz)

Java Underground
Java Underground
169 участник(ов)

https://vk.com/javatutorial

Javanese Questions
Javanese Questions
109 участник(ов)

Чат предназначен для обмена знаниями строго в формате в вопрос-ответ. Тема — Java, Kotlin и Android. Вопрос должен быть предварительно прогуглен, понятно и грамотно сформулирован, помечен хэштегами. Ответ — тем более. Куски кода размером в несколько строк можно писать прямо здесь, для больших кусков кода стоит использовать http://gist.github.com/, http://pastebin.com/, https://codeshare.io/ или любой аналогичный сервис. В некоторых случаях можно прикреплять скриншоты. Стикеры и гифки запрещены. Дополнять и уточнять вопросы и ответы — редактированием исходного сообщения. Обсуждения должны приводить к редактированию вопроса/ответа и удаляться. По хештегам можно искать существующие вопросы и овтеты: #вопрос #ответ #git #generics #java #server #awt #javafx #swing #kotlin #anko #tornadofx #ktor #android #recyclerView #performance #arch #network #permissions #storage #async