Вопросы

Я сделал возраст игроку,в бд все четко записалось,но в переменную игрока нет. в БД 18, а в переменной 110.

enum pdata
{
pID,
pNick,
pPassword,
pAge,
pCash
};
new pInfo[MAX_PLAYERS][pdata];
public OnPlayerConnect(playerid)
{
    ClearInfoPlayer(playerid);
    GetPlayerName(playerid,pInfo[playerid][pNick],MAX_PLAYER_NAME);
    new query[100];
    format(query,sizeof(query),"SELECT * FROM `accounts` WHERE `pNick` = '%s'",pInfo[playerid][pNick]);
    mysql_function_query(sql,query,true,"CheckUserReg","i",playerid);
    SetPlayerCameraPos(playerid,-129.7357,645.5155,30.0010);
    SetPlayerCameraLookAt(playerid,-129.7357,645.5155,30.0010);
    return 1;
}
public OnPlayerDisconnect(playerid, reason)
{
    GetPlayerName(playerid,pInfo[playerid][pNick],MAX_PLAYER_NAME);
    new query[100 + MAX_PLAYER_NAME + 24];
    format(query,sizeof(query),"UPDATE `accounts` SET `pPassword` = '%s',`pAge` = '%d',`pCash` = '555' WHERE `pNick` = '%s'",pInfo[playerid][pPassword],pInfo[playerid][pAge],pInfo[playerid][pCash],pInfo[playerid][pNick]);
    mysql_query(sql,query);
    ClearInfoPlayer(playerid);
    return 1;
}
public OnDialogResponse(playerid, dialogid, response, listitem, inputtext[])
{
    switch(dialogid)
    {
        case D_REG:
        {
            if(!response) return Kick(playerid);
            if(strlen(inputtext) < 4 || strlen(inputtext) > 30 || strlen(inputtext) == 0return ShowReg(playerid);
            for(new i; i < strlen(inputtext); i++)
            {
                switch(inputtext[i])
                {
                    case 'a'..'z','A'..'Z','0'..'9':continue;
                    defaultreturn ShowReg(playerid);
                }
            }
            GetPlayerName(playerid,pInfo[playerid][pNick],24);
            new query[77 + MAX_PLAYER_NAME + 30];
            format(query,sizeof(query),"INSERT INTO `accounts` (`pNick`,`pPassword`,`pAge`) VALUES ('%s','%s','0')",pInfo[playerid][pNick],inputtext);
            mysql_function_query(sql,query,false,"","");
            strmid(pInfo[playerid][pPassword], inputtext, 0, strlen(inputtext), 32);
            ShowDAge(playerid);
   }
        case D_AGE:
        {
            if(!response) return Kick(playerid);
            for(new i; i < strlen(inputtext); i++)
            {
                switch(inputtext[i])
                {
                    case '0'..'9':continue;
                    defaultreturn ShowDAge(playerid);
                }
            }
            new query[100];
            GetPlayerName(playerid,pInfo[playerid][pNick],24);
            format(query,sizeof(query),"UPDATE `accounts` SET `pAge` = '%i' WHERE `pNick` = '%s'",strval(inputtext),pInfo[playerid][pNick]);
            mysql_function_query(sql,query,false,"Spawn","i",playerid);
            SpawnPlayer(playerid);
            strmid(pInfo[playerid][pAge],inputtext,0,strlen(inputtext),3);
        }
        case D_LOG:
        {
            if(!response) return Kick(playerid);
            if(strlen(inputtext) < 4 || strlen(inputtext) > 30 || strlen(inputtext) == 0return ShowLogin(playerid);
            if(!strcmp(pInfo[playerid][pPassword],inputtext))
            {
                SpawnPlayer(playerid);
                SetPlayerSkin(playerid,5);
            }
            else
            {
                return ShowLogin(playerid);
            }
        }
    }
    return 1;
}
stock ShowDAge(playerid)
{
    ShowPlayerDialog(playerid,D_AGE,DIALOG_STYLE_INPUT,"Возраст","Укажие возраст ниже","Далее","");
    return 1;
}
stock ShowReg(playerid)
{
    ShowPlayerDialog(playerid,D_REG,DIALOG_STYLE_INPUT,"Регистрация","Введите пароль ниже","Далее","");
    return 1;
}
stock ShowLogin(playerid)
{
    ShowPlayerDialog(playerid,D_LOG,DIALOG_STYLE_INPUT,"Авторизация","Введите пароль ниже","Далее","");
    return 1;
}
forward CheckUserReg(playerid);
public CheckUserReg(playerid)
{
    new rows[2];
    cache_get_data(rows[0],rows[1]);
    if(!rows[0])
    {
        ShowReg(playerid);
    }
    else
    {
        ShowLogin(playerid);
        cache_get_field_content(0,"pPassword",pInfo[playerid][pPassword],sql,30);
    }
    return 1;
}
forward Spawn(playerid);
public Spawn(playerid)
{
    pInfo[playerid][pID] = cache_get_field_content_int(0,"pID",sql);
    pInfo[playerid][pNick] = cache_get_field_content(0,"pNick",pInfo[playerid][pNick],sql,24);
    pInfo[playerid][pPassword] = cache_get_field_content(0,"pPassword",pInfo[playerid][pPassword],sql,30);
    pInfo[playerid][pAge] = cache_get_field_content_int(0,"pAge",sql);
    SpawnPlayer(playerid);
    SetPlayerSkin(playerid,280);
    return 1;
}
CMD:test(playerid)
{
    GetPlayerName(playerid,pInfo[playerid][pNick],24);
    new nick[30],age[15];
    format(nick,sizeof(nick),"Ник: %s",pInfo[playerid][pNick]);
    format(age,sizeof(age),"Возраст: %d",pInfo[playerid][pAge]);
    SendClientMessage(playerid,-1,nick);
    SendClientMessage(playerid,-1,age);
}
stock ClearInfoPlayer(playerid)
{
pInfo[playerid][pID] = 0;
pInfo[playerid][pNick] = EOS;
pInfo[playerid][pPassword] = EOS;
pInfo[playerid][pAge] = 0;
}

При вводе /test в возрасте пишет 110

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

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


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

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

  • 0

Не вижу проблемы в коде, проблема у вас с глазами (ни в коем случае не оскорбление)

Дело в том, что при вводе правильного пароля, вы спавните игрока так:

SpawnPlayer(playerid);

Но, запрос возраста игрока из БД и присвоение его к переменной у вас прописано в этом паблике:

Spawn(playerid)

 

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

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


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

@Sleash`en я понял, допустим он записался, но при вводе команды /test все равно пишет 110. 

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


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

@Antoxa39 Тогда уж скорее всего придётся заново запросить данные с БД, и продолжать через паблик, как вы это делали с CheckUserReg

Не знаю почему, но я тоже сталкивался с тем, что запросы обрабатываются ТОЛЬКО при отсылке к паблику (А возможно это и баг инклуда с плагином) 

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


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

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

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

    • Talex
      От Talex
      Всем привет, сливаю первый мод!
      Информация о моде:

      — Основа Gamenix.
      — Мод переведен на Mysql R39, теперь ни каких слётов нет, мод работает стабильно с онлайном 160+.
      — Новый автосалон на TextDraw.
      — Система 3-х автомобилей (1 можно купить по дефолту, 2 и 3 за донат).
      — Автомобили у игроков теперь не пропадают (Id'ы авто сбивались, с номерами теперь тоже всё в порядке).
      — Оформление сервера полностью переработано, теперь оно более красивое.
      — Защита от копирования карты.
      — в меню сервера добавлен пункт визуальных настроек.
      — Номера на транспорт теперь можно приобрести в /donate.
      — Сделан новый красивый спидометр.
      — При получении номера, добавлен выбор региона.
      — Сделана система радаров и промокодов, создание прямо из игры.
      — Новый интерьер казино.
      — Магазин скинов теперь на TextDraw.
      — Автошкола полностью функционирует.
      — Добавлена информация после коннекта о последнем входе в собственный аккаунт.
      — Приватная защита от всех видов DDoS атак и DoS атак.                                                                                                                                    
      — пароль от АП (/alog) теперь у каждого администратора индивидуальный.
      — Изменено оформление самого мода
      Это не все изменения мода, их ещё очень много. все не упомнишь. 
      Автор мода: Неизвестен
      CUNBERS RP 8.4.3.rar