Вопросы

Привет! У меня возникла проблема связанная с 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, "Данный аккаунт  не зарегестрирован");
}

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

Поделиться сообщением


Ссылка на сообщение

7 ответов на этот вопрос

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

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

Поделиться сообщением


Ссылка на сообщение
  • 0
SELECT id FROM users WHERE name = "%s";

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

Отредактировано пользователем Раксон Фаркрай

Поделиться сообщением


Ссылка на сообщение
  • 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)

 

Поделиться сообщением


Ссылка на сообщение
  • 0
SELECT `id` FROM users WHERE name = '%s';

Пробуй так

Отредактировано пользователем Раксон Фаркрай

Поделиться сообщением


Ссылка на сообщение
  • 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

Поделиться сообщением


Ссылка на сообщение
  • 0

@Раксон Фаркрай БОЖЕ СПАСИБО ЧТО БЫЛ СО МНОЙ ВСЕ ТЕПЕРЬ РОБИТ

Поделиться сообщением


Ссылка на сообщение
  • 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';

 

Поделиться сообщением


Ссылка на сообщение
Гость
Эта тема закрыта для публикации ответов.
  • Последние посетители   0 пользователей онлайн

    Ни одного зарегистрированного пользователя не просматривает данную страницу

  • Похожий контент

    • Доналдо Фарекелка
      От Доналдо Фарекелка


      Скачать файл Arizona RolePlay || Ser
      Приветствую, этот мод я нашёл на просторах интернета. 
      Скачал мод у автора:  Developer Stravinskiy
      Доработал мод: Donaldo_Farekelka
       
      Предупреждаю! Мод сырой, багов стало меньше, но они есть.
      Мод: Баня, Подвал, В некоторых местах маппинг, система коронавируса, 8 лвл админок
       
      Информация:
      1) Dc_Cmd
      2) Mysql, mode, language - Всё настраивается теперь в pawno ( UPDATE: 1.1.0 )
      3) Административные права в данный момент можно выдать только через MYSQL ( BD ).
       
      То что я сделал ( Всё что я делаю сейчас, смотрите в изменениях ):
       
      Добавил Доналдо Фарекелка Добавлено 13.04.2023 Категория Моды Автор shenol (vk.com/donaldo_farekelka)  
    • gooding
      От gooding
      Доброго времени суток! Я выложил на продажу игровой мод RedRow RolePlay!
       
      17 ТИТУЛОВ, 14 КОСТЮМОВ (КАМЕРМЭН, ФЕЯ, СИ-ДЖЕЙ, ДЭДПУЛ, СПАНЧ БОБ, НИНДЗЯ, ДЕД МОРОЗ и другие!),
      BMW I8, BMW M5, BMW Vision M NEXT, Mercedes-Benz G-CLASS, Rolls-Royce Phantom! Система рулетки  (Исправлена, теперь не выпадает одно и то же),
      Автопарки Фракций (FBI и банд), МОД ОПТИМИЗИРОВАЛИ под ИГРУ, ДОБАВИЛИ НОВЫЙ АНТИЧИТ (Latest Nex-AC) и АНТИЧИТ настроен. Проделано много работы (Над модом работали полгода) и исправили множество багов.
       
      Что было добавлено?
      1. 17 титулов,
      2. 14 костюмов,
      3. Эксклюзивный транспорт (SandKing, Rolls-Royce Phantom, BMW I8, BMW M5, BMW Vision M NEXT, Mercedes-Benz G-CLASS).
      4. Автопарк ФБР и всех банд.
      5. Новый анти-чит.
      6. Оптимизация игрового мода.
      7. Премиум и уникальные возможности для владельцев Премиума.
      8. Команда /bonus, где можно получить бесплатно Red Coins.
      9. За АКТИВ даются Red Coins!
      10. Рестарт сервера в 5:00 по МСК.
      11. Радужный клист.
      12. Уникальный тюнинг для эксклюзивных машин и ускорение.
      13. Новая система банка.
      14. Исправлено множество багов.
      15. Новый маппинг.
    • Redmondd
      От Redmondd
      Хочу сделать команду /gpsoff, которая убирает метку