Вопросы

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

Спойлер

c:setyoutuber;
{
    if(pData[playerid][pAdmin] < 7 || !GetPVarInt(playerid,"AdminLogin")) return true;
    new
        Nick [MAX_PLAYER_NAME + 1],
        Promo [20],
        Level,
        id;
    if(sscanf(params,"s[64]ds[20]", Nick,Level,Promo)) return SendInf(playerid, "Используйте: /setyt [NAME] [LVL] [PROMO] ( Для снятия везде нули )");
    if(Level > 2 || Level < 0return SendErr(playerid, "Значение не может быть меньше 0 и больше 2");
    new offwarnq[150];
    format(offwarnq,sizeof offwarnq,"SELECT `id` FROM `accounts` WHERE `nickname` = '%s'",Nick);
    mysql_query(MySQLGo, offwarnq);
    id = cache_get_field_content_int(0"id");
    if(!cache_num_rows()) return SendErr(playerid,"Ошибка. Аккаунт не найден");
    else
    {
        new ingame = -1;
        foreach(new i: Player)
        {
            if(!IsPlayerConnected(i))continue;
            if(!strcmp(Nick,pData[i][pNickname],true))ingame = 1;
            break;
        }
        if(ingame == -1)
        {
            if(Level == 0)
            {
                new query[144];
                format(query,sizeof(query),"DELETE FROM `youtubers` WHERE `mysql_id` = '%d'",id); // UPDATE `accounts` SET `youtube` = '0',`youtubedate` = '',`youtubepromo` = '' WHERE `id` = '%d'
                mysql_query(MySQLGo, query);
                SFCM(playerid,-1,"Вы сняли права ютубера у игрока {0099ff}%s{ffffff}.",Nick);
                return true;
            }
            new year, month, day;
            getdate(year, month, day);
            if(strlen(Promo) < 1 || strlen(Promo) > 20)return SendErr(playerid, "Используйте: /setyoutuber [NAME] [LVL] [PROMO](1-20)");
            new query[256];
            format(query,sizeof(query),"INSERT INTO `youtubers` (`mysql_id`, `level`, `promo`, `date`, `whoput`) VALUES ('%d', '%d', '%s', '%0d.%02d.%d', '%s')", id, Level, Promo, day, month, year, pData[playerid][pNickname]);
            mysql_query(MySQLGo, query);
            
            SFCM(playerid,-1,"Вы выдали права ютубера игроку {0099ff}%s{ffffff}. Промокод: {0099ff}%s {ffffff}[LEVEL: %d]",Nick,Promo,Level);
        }
        else
        {
            new player = GetPlayerID(Nick);
            if(!pData[player][pMysqlID] || !IsPlayerConnected(player)) return SendErr(playerid, "Данный игрок не авторизован.");
            if(Level == 0)
            {
                if(yData[player][yLevel] == 0return SendErr(playerid, "Игрок не имеет полномочий ютубера.");
                new query[144];
                format(query,sizeof(query),"DELETE FROM `youtubers` WHERE `mysql_id` = '%d'",id);
                mysql_query(MySQLGo, query);
                yData[player][yLevel] = 0;
                SFCM(player, -1"Администратор {0099ff}%s {ffffff}аннулировал вам полномочия ютубера",pData[playerid][pNickname]);
                SFCM(playerid, -1"Аннулирование прав ютубера у игрока {0099ff}%s {ffffff}прошло успешно", pData[player][pNickname]);
                SetPVarInt(playerid,"YoutubeLogin",0);
                return true;
            }
            new year, month, day;
            getdate(year, month, day);
            if(yData[player][yLevel] > 0return SendErr(playerid, "Игрок уже имеет полномочия ютубера.");
            if(strlen(Promo) < 1 || strlen(Promo) > 20)return SendErr(playerid, "Используйте: /setyoutuber [NAME] [LVL] [PROMO](1-20)");
            new query[256];
            format(query,sizeof(query),"INSERT INTO `youtubers` (`mysql_id`, `level`, `promo`, `date`, `whoput`) VALUES ('%d', '%d', '%s', '%0d.%02d.%d', '%s')", id, Level, Promo, day, month, year, pData[playerid][pNickname]);
            mysql_query(MySQLGo, query);
            SFCM(playerid,-1,"Вы выдали права ютубера игроку {0099ff}%s{ffffff}. Промокод: {0099ff}%s {ffffff}[LEVEL: %d]",Nick,Promo,Level);
            yData[player][yLevel] = Level;
        }
    }
    return true;
}

 

 

Отредактировано пользователем trevison

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


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

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

  • 0

Незнаю поможет-ли но вот.


        
        new query_check[144];
        format(query_check, sizeof(query_check), "SELECT `id` FROM `youtubers` WHERE `mysql_id` = '%d'", id);
        mysql_query(MySQLGo, query_check);

        if (cache_num_rows()) return SendErr(playerid, "Игрок с таким ником уже является ютубером.");



 

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


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

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

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

    • От MrNARTI
      всем привет появилась ошибка со входам в автосалон, ерроров нету но при попытки входа показывает что есть транспорт загруженный хотя его нету. Но когда ввожу /car показывает что есть хотя повторяюсь его нет.
       
      код
       
      команда /саr
       
       
       
      если понадобится что то еще скинуть то скажите я скину.
    • От MrNARTI
      всем привет можете пожалуйста подсказать с командой от анти слива /aban
       
      чтобы банило и администратора который использовал эту кмд и адм которого указал в айди.