Форум программистов, компьютерный форум, киберфорум
PostgreSQL
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.75/4: Рейтинг темы: голосов - 4, средняя оценка - 4.75
34 / 47 / 40
Регистрация: 20.03.2013
Сообщений: 185

Go выдает синтаксическую ошибку при обращении с запросом к БД

21.01.2024, 15:48. Показов 893. Ответов 9
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте!

Пишу на Go. Работаю с Postgresql. Подключение к базе данных происходит. с этим все нормально.

Но почему-то следующий код выдает ошибку.

Go
1
rows, errr = db.Query("SELECT * FROM public.people WHERE (age=?) AND (surname=?)", age+1, surname)
, где переменная age - int, surname - string.

Ошибка следующая: синтаксическая ошибка (положение примерно ")"). Если убрать скобки, то положение ошибки будет "AND".

Не знаю с чем связано, вероятно со знаком вопроса около age. Кавычки пытался туда ставить. не знаю в чем проблема. Простой запрос без ? вроде работает.

Подскажите, пожалуйста
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
21.01.2024, 15:48
Ответы с готовыми решениями:

При выполнении запроса выдает синтаксическую ошибку
при выполнении запроса выдает синтакстическая ошибка посмотрите пожалуйста где ошибка SELECT "Заказчик"."Наименование...

При запуске ASP приложений на локальной машине ИЕ выдает синтаксическую ошибку
При запуске ASP приложений на локальной машине ИЕ выдает синтаксическую ошибку... не могу поеять в чем дело... причем не важно сам писал...

Выдает ошибку при обращении к созданному классу
у меня есть код, в нем есть метод, он увеличивает размер класса в массиве, обращается к классу через длину массива -1, и устанавливает его...

9
367 / 332 / 83
Регистрация: 17.04.2022
Сообщений: 1,112
Записей в блоге: 8
21.01.2024, 16:14
Абстрактный методологический совет.
Используйте какой-нибудь гуишный sql просмотрщик. (например dbeaver)
отладьте сначала запрос в нем. Я подозреваю отсутствие обрамляющих кавычек для строкового (?) значения surname.
0
34 / 47 / 40
Регистрация: 20.03.2013
Сообщений: 185
21.01.2024, 16:36  [ТС]
Попробовал в pgadmin sql запрос:
SQL
1
SELECT * FROM public.people WHERE age=? AND surname='?'
заместо вопросов значения вставил. там все работает.

но программа выдает синтаксическую ошибку. говорит примерное положение около AND
0
34 / 47 / 40
Регистрация: 20.03.2013
Сообщений: 185
21.01.2024, 16:40  [ТС]
вот сама таблица если что
Миниатюры
Go выдает синтаксическую ошибку при обращении с запросом к БД  
0
 Аватар для Аватар
5393 / 1465 / 513
Регистрация: 31.05.2012
Сообщений: 5,153
21.01.2024, 17:18
Либо для строкового параметра кавычки не проставляются, либо в том районе какой-то не отображаеимый символ затесался. Попробовать перебрать ту строку
0
34 / 47 / 40
Регистрация: 20.03.2013
Сообщений: 185
21.01.2024, 17:33  [ТС]
Строка запроса в смысле?
0
367 / 332 / 83
Регистрация: 17.04.2022
Сообщений: 1,112
Записей в блоге: 8
21.01.2024, 17:50
Цитата Сообщение от ilyadenisovid Посмотреть сообщение
SELECT * FROM public.people WHERE (age=?) AND (surname=?)
Цитата Сообщение от ilyadenisovid Посмотреть сообщение
SELECT * FROM public.people WHERE age=? AND surname='?'
разница есть?
0
34 / 47 / 40
Регистрация: 20.03.2013
Сообщений: 185
21.01.2024, 18:00  [ТС]
В пгадмине второй вариант работает. А в программе ни один из них
0
367 / 332 / 83
Регистрация: 17.04.2022
Сообщений: 1,112
Записей в блоге: 8
21.01.2024, 18:48
попробуйте заменить на свою подстановку
Go
1
rows, errr = db.Query(fmt.Sprintf("SELECT * FROM public.people WHERE (age=%d) AND (surname='%s')", age+1, surname)
или используйте prepared statements

кстати, как написано здесь https://go.dev/doc/database/prepared-statements, постгре вместо ? предпочитает $1

PS
1) я сам использую параметризованные запросы только в prepared statements
2) попробуйте https://github.com/jmoiron/sqlx. Эта библиотека значительно более удобна, нежели стандартная
0
34 / 47 / 40
Регистрация: 20.03.2013
Сообщений: 185
21.01.2024, 21:01  [ТС]
Спасибо

Добавлено через 1 час 22 минуты
Оказалось нужно было просто ? заменить на $1, $2 и так далее, причем без кавычек. И все заработало. Возможно именно так работает postgresql. Спасибо
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
21.01.2024, 21:01
Помогаю со студенческими работами здесь

При обращении ко втором файлу выдаёт ошибку несоответствия типа
В случае одного файла работает отлично, но при подключении второго выдаёт ошибку. Sub test() Dim WorkBook2, WorkBook3 As...

Zend Server при обращении к панели выдает 500 ошибку
:hi: Установил Zend Server на VDS При обращении к панели (1.1.1.1:10081/ZendServer/) выдается ошибка 500, иногда 503 Сайты...

Выдаёт синтаксическую ошибку
Всем привет, я только начинаю учить php. Решил написать небольшой скрипт. Вот мой код: При запуске мне выдаёт синтаксическую...

Выдает синтаксическую ошибку
Здравствуйте. Только начал учить PHP. Смотрю видеоуроки. Дошел до 8 урока и при наборе кода выдало ошибку: Database query failedYou have an...

Выдаёт синтаксическую ошибку в 14 строке
Здравствуйте, я написал код БД по самоучителю, и почему то у меня выдаёт ошибку в 14 строке, хотя я написал всё верно как там, помогите...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
10
Ответ Создать тему
Новые блоги и статьи
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip На первой гифке отладочные линии отключены, а на второй включены:. . .
SDL3 для Web (WebAssembly): Идентификация объектов на Box2D v3 - использование userData и событий коллизий
8Observer8 02.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-collision-events-sdl3-c. zip Сканируйте QR-код на мобильном и вы увидите, что появится джойстик для управления главным героем. . . .
Реалии
Hrethgir 01.03.2026
Нет, я не закончил до сих пор симулятор. Эта задача сложнее. Не получилось уйти в плавсостав, но оно и к лучшему, возможно. Точнее получалось - но сварщиком в палубную команду, а это значит, в моём. . .
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
SDL3 для Web (WebAssembly): Сборка библиотек: SDL3, Box2D, FreeType, SDL3_ttf, SDL3_mixer и SDL3_image из исходников с помощью CMake и Emscripten
8Observer8 27.02.2026
Недавно вышла версия 3. 4. 2 библиотеки SDL3. На странице официальной релиза доступны исходники, готовые DLL (для x86, x64, arm64), а также библиотеки для разработки под Android, MinGW и Visual Studio. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru