Question

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

Спойлер

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;
}

 

 

Edited by trevison

Share this post


Link to post

1 answer to this question

  • 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, "Игрок с таким ником уже является ютубером.");



 

Share this post


Link to post
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

    • By def
      arizona.pwn(23374) : error 012: invalid function call, not a valid address
      arizona.pwn(23374) : error 001: expected token: ";", but found ")"
      arizona.pwn(23374) : error 029: invalid expression, assumed zero
      arizona.pwn(23374) : fatal error 107: too many error messages on one line
      жалуется на данную строчку:
       
      %s{cccccc}Для продолжения нажмите 'Далее'",PN(playerid),playerid,ItemsInfo[itemid][ItemName2],hours,cost*hours,Inventory[playerid][2][slot], AksColorName(Inventory[playerid][4][slot]), Inventory[playerid][5][slot] ? GetNameStripe(Inventory[playerid][5][slot]) : "");