Question

trevison
Активный

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

Спойлер

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

    • gooding
      By gooding


      Скачать файл PAR RP | Уникальный мод без багов
      Всем здравствуйте, уважаемые читатели. Я много времени потратил на доработку данного игрового мода, чтобы его выставить на форум.
      Лог доработок можно посмотреть внизу, а скриншоты игрового мода внизу и верху.
       
       

      Добавил gooding Добавлено 20.11.2024 Категория Моды Автор GOODING (Я)  
    • gooding
      By gooding
      Всем здравствуйте, уважаемые читатели. Я много времени потратил на доработку данного игрового мода, чтобы его выставить на форум.
      Лог доработок можно посмотреть внизу, а скриншоты игрового мода внизу и верху.
       
       

    • Kalinin
      By Kalinin
      1. Набираю команду для создания CRMP сервера.
      2. Вакансии  которые свободны. Связь через TG @kalinin_sql
      Нам нужны;
      1.Кодеры
      2.Маперы
      3.СММ
      Так-же дружная работа. По поводу зарплаты будем обговаривать все лично в беседе ТГ
       
    • whccompany
      By whccompany
      Rostov Role Play | Rostov RP | CRMP Mobile Project объявляет набор людей в свою команду: Нам требуются:
       
      1. Маппера:
      Сдельная оплата труда от 250 до 3000 рублей/ за 1 работу
       
      2. Специалист по Text Draw:
      Сдельная оплата труда от 400 до 3500 рублей/ за одну работу
       
      3. Pawn разработчик:
      Заработная плата от 10 000 рублей/месяц
       
      4. Программист для создания лаунчера и сайта UCP с автодонатом:
      Заработная плата от 10 000 рублей/месяц
       
      Контакты для связи:
       
      ВКонтакте
       
      Telegram