Question

Привет! У меня возникла проблема связанная с mysql. Мне нужно было сделать так, чтобы если в базе данных если есть аккаунт, то выводил бы сообщение в чат игры Данный аккаунт зарегистрирован, если нету в базе данных аккаунта, то тогда бы сообщение выглядело так. Данный аккаунт зарегистрирован. Но не тут так было. В файле по дирректории logs\errors.log записывается следующее сообщение

 

[22:09:01] [plugins/mysql] error #1064 while executing query "SELECT 'id' FROM 'users' WHERE 'name' = 'Ruslan_Linux'": 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 ''users' WHERE 'name' = 'Ruslan_Linux'' at line 1 (C:\Users\Ruman\Desktop\Time RP\gamemodes\timerp.pwn:86)

Жаловался он на код в строке 86. Ниже код который отвечает за там по моему за определение в базе есть ли аккаунт и т.д.

 

public OnPlayerConnect(playerid)
{
    GetPlayerName(playerid, player_info[playerid][NAME], MAX_PLAYER_NAME);
    static const fmt_query[] = "SELECT 'id' FROM 'users' WHERE 'name' = '%s'";
    new query[sizeof(fmt_query)+(-2+MAX_PLAYER_NAME)];
    format(query, sizeof(query), fmt_query,  player_info[playerid][NAME]);
    mysql_tquery(dbHandle, query, "CheckRegistartion""i", playerid);
}

forward CheckRegistartion(playerid);
public CheckRegistartion(playerid)
{
    new rows;
    cache_get_row_count(rows);
    if(rows) ShowLogin(playerid);
    else ShowRegistration(playerid);
}

stock ShowLogin(playerid)
{
    SCM(playerid, COLOR_WHITE, "Данный аккаунт зарегестрирован");
}
stock ShowRegistration(playerid)
{
    SCM(playerid, COLOR_WHITE, "Данный аккаунт  не зарегестрирован");
}

Я ОЧЕНЬ надеюсь, что моя проблема будет решена!

Share this post


Link to post

7 answers to this question

  • 2
format(query, sizeof(query), "SELECT `id` FROM users WHERE name = '%s';",  player_info[playerid][NAME]);

попробуй сделать так

Share this post


Link to post
  • 0
SELECT id FROM users WHERE name = "%s";

Попробуйте такой запрос

Edited by Раксон Фаркрай

Share this post


Link to post
  • 0

@Раксон Фаркрай Вот что происходит при компиляции

C:\Users\Ruman\Desktop\Time RP\gamemodes\timerp.pwn(83) : error 001: expected token: "-string end-", but found "-identifier-"
C:\Users\Ruman\Desktop\Time RP\gamemodes\timerp.pwn(83) : error 029: invalid expression, assumed zero
C:\Users\Ruman\Desktop\Time RP\gamemodes\timerp.pwn(83) : error 017: undefined symbol "s"
C:\Users\Ruman\Desktop\Time RP\gamemodes\timerp.pwn(83) : fatal error 107: too many error messages on one line

Compilation aborted.

Pawn compiler 3.10.10           Copyright (c) 1997-2006, ITB CompuPhase


4 Errors.

 

@Раксон Фаркрай Только что скачал более старую теперь в лог выдает

[00:20:44] [plugins/mysql] Р/` (C:\Users\Ruman\Desktop\Time RP\gamemodes\timerp.pwn:86)

 

Share this post


Link to post
  • 0
SELECT `id` FROM users WHERE name = '%s';

Пробуй так

Edited by Раксон Фаркрай

Share this post


Link to post
  • 0

@Раксон Фаркрай 

Pawn compiler 3.10.10           Copyright (c) 1997-2006, ITB CompuPhase

Header size:           2264 bytes
Code size:            10276 bytes
Data size:           518780 bytes
Stack/heap size:      16384 bytes; estimated max. usage=79 cells (316 bytes)
Total requirements:  547704 bytes

Done.

Уже компилируется но так как задумано это не работает то есть вывод сообщения командой SendClientMessage

Share this post


Link to post
  • 0

@Ruman, на будущее: в языке SQL одинарные кавычки используются для строковых данных, а апострофы – для названий таблиц, столбцов... И, если опускание одинарных кавычек недопустимо, то опускание апострофов вполне возможно, если название таблицы/столбца не является ключевым словом языка SQL. В вашем случае вполне допустимы все нижеперечисленные варианты.

SELECT id FROM users WHERE name = '%s';

SELECT `id` FROM `users` WHERE `name` = '%s';
SELECT `id` FROM `users` WHERE name = '%s';
SELECT `id` FROM users WHERE `name` = '%s';
SELECT `id` FROM users WHERE name = '%s';

SELECT id FROM `users` WHERE `name` = '%s';
SELECT id FROM `users` WHERE name = '%s';
SELECT id FROM users WHERE `name` = '%s';
SELECT id FROM users WHERE name = '%s';

 

Share this post


Link to post
Guest
This topic is now closed to further replies.
Sign in to follow this  
Followers 0
  • Recently Browsing   0 members

    No registered users viewing this page.

  • Similar Content

    • nnnumber1
      By nnnumber1
      Доброго времени суток, совсем недавно начал свой путь разработчика в САМП/КРМП, ищу интересный проект для взаимовыгодного сотрудничества.
      Хочется "набивать руку" и повышать свой уровень в реальных условиях!

      Пишите в ЛС на форуме.
    • Makkos
      By Makkos
      Ищу человека которий может сделать лаунчер мобайл для самп проекта
      Оплата в - грн
      Жду предложений в телеграм - https://t.me/creator700
    • malibu-rp
      By malibu-rp
      Игровой проект GTA SAMP ищет в свою команду:
       
      1. Скриптер
      2. Маппер
       
      Требования и обязанности:
       
      Скриптер
       
      Требования:
       
      1. Готовность и умение работать с new.pwn
      2. Знание языка PAWN
      3. Умение создавать системы/работы/фракции
       
      Обязанности:
       
      1) Создавать системы/работы/фракции
      2) Давать актуальные советы по разработке руководству проекта
       
       
      Условия работы:
      1. Заработная плата в первые 3 месяца от 2500 до 6000 рублей в месяц +20% от дохода проекта
      2. Наличие Discord для связи с руководством проекта
      3. Возможно официальное оформление по трудовому договору/договору найма/договору ГПХ
      4. Премирование в праздничные дни и день рождения
       
       
      Маппер
       
      Требования
       
      1) Умение делать качественный маппинг
      2) Умение создавать экстерьеры
      3) Умение создавать интерьеры
       
      Обязанности:
       
      1. Создавать городской маппинг
      2.Создавать экстерьеры
      3.Создавать фракционный маппинг
      4. Создавать интерьеры
       
       
      Условия работы:
      1. Заработная плата в первые 3 месяца от 2500 до 6000 рублей в месяц +20% от дохода проекта
      2. Наличие Discord для связи с руководством проекта
      3. Возможно официальное оформление по трудовому договору/договору найма/договору ГПХ
      4. Премирование в праздничные дни и день рождения
       
      Для связи пишите в лс или в сообщения группы вк: Группа проекта
    • defaultValue
      By defaultValue
      PAEditor - редактор для прикрепления объектов
      Скачать файл PAEditor

      Цель была разработать редактор для прикрепления объектов (PAEditor) с удобным интерфейсом.
       
      Язык интерфейса:
      English Русский Український Беларускі

      Начать:
      Для начала работы нужно нажать клавишу Y Можно создать проект и загрузить. (Проект сохраняется сам)
      Кнопки:

      Manage:
      Нажатие левой кнопки мыши, открывает диалог для выбора одного аттача. Нажатие правой кнопки мыши, открывает диалог для выбора несколько аттачей одновременно.
      Export:
      Экспортирует ваш проект в файл. Путь scriptfiles > project > export
      New:
      Создать процесс для аттача
      Delete:
      Удалить текущий аттач
      Dublicate:
      Продублировать текущий аттач (объект сохраняет свой размер и координаты от оригинала)
      Objects:
      Нажатие левой кнопки мыши, открывает диалог, где вы можно ввести, добавить или открыть список объектов. Нажатие правой кнопки мыши, открывает сразу список объектов.
      Bone:
      Изменить кость для текущего аттача.
      Symmetry:
      Симметрично отзеркаливает текущий объект и перемещает его на противоположную кость, т.е. если объект был в левой руки, то будет перемещен в правую руку.
      Если противоположной кости нет то остается на той же. т.е. если это голова, то там и остается.  
      Edit:
      ачать редактировать аттач.
      Colors:
      Нажатие левой кнопки мыши, открывает диалог, где вы можно ввести, добавить или открыть список цветов (добавленные цвета сохраняются). Нажатие правой кнопки мыши, открывает сразу список цветов.
      Camera Move:
      Включить/отключить вращение камеры в панели быстрого доступа
      Animation:
      Можно установить анимацию и добавить в список (добавленные анимации сохраняются)
      Clear Anim:
      Очистить текущею анимацию
      Prev & Next Skin:
      Нажатие левой кнопки мыши, быстрое переключение скина. Нажатие правой кнопки мыши, быстрое переключение скина и автоматический экспорт проект
      Skin:
      Установить скин  
      Скриншоты:
       
       
      Для запуска сервера, откройте папку, запустите samp-server.exe и в SAMP мультиплеере добавьте адрес 127.0.0.1.

      Всегда актуальная версия  >> GitHub

      Автор: Saibot
      Добавил defaultValue Добавлено 28.02.2024 Категория Скрипты Автор Saibot  
    • defaultValue
      By defaultValue
      PAEditor

      Цель была разработать редактор для прикрепления объектов (PAEditor) с удобным интерфейсом.
       
      Язык интерфейса:
      English Русский Український Беларускі

      Начать:
      Для начала работы нужно нажать клавишу Y Можно создать проект и загрузить. (Проект сохраняется сам)
      Кнопки:

      Manage:
      Нажатие левой кнопки мыши, открывает диалог для выбора одного аттача. Нажатие правой кнопки мыши, открывает диалог для выбора несколько аттачей одновременно.
      Export:
      Экспортирует ваш проект в файл. Путь scriptfiles > project > export
      New:
      Создать процесс для аттача
      Delete:
      Удалить текущий аттач
      Dublicate:
      Продублировать текущий аттач (объект сохраняет свой размер и координаты от оригинала)
      Objects:
      Нажатие левой кнопки мыши, открывает диалог, где вы можно ввести, добавить или открыть список объектов. Нажатие правой кнопки мыши, открывает сразу список объектов.
      Bone:
      Изменить кость для текущего аттача.
      Symmetry:
      Симметрично отзеркаливает текущий объект и перемещает его на противоположную кость, т.е. если объект был в левой руки, то будет перемещен в правую руку.
      Если противоположной кости нет то остается на той же. т.е. если это голова, то там и остается.  
      Edit:
      ачать редактировать аттач.
      Colors:
      Нажатие левой кнопки мыши, открывает диалог, где вы можно ввести, добавить или открыть список цветов (добавленные цвета сохраняются). Нажатие правой кнопки мыши, открывает сразу список цветов.
      Camera Move:
      Включить/отключить вращение камеры в панели быстрого доступа
      Animation:
      Можно установить анимацию и добавить в список (добавленные анимации сохраняются)
      Clear Anim:
      Очистить текущею анимацию
      Prev & Next Skin:
      Нажатие левой кнопки мыши, быстрое переключение скина. Нажатие правой кнопки мыши, быстрое переключение скина и автоматический экспорт проект
      Skin:
      Установить скин  
      Скриншоты:
       
       
      Для запуска сервера, откройте папку, запустите samp-server.exe и в SAMP мультиплеере добавьте адрес 127.0.0.1.

      Всегда актуальная версия  >> GitHub

      Автор: Saibot