Вопросы

Всем доброе времени суток пользователям pawno-rus, я не так давно начал изучать mysql, и уже столкнулся с такой проблема :(
Хочу сделать вип по дням, но почему-то не загружается дата вип аккаунта. Получается всегда захожу на сервер а пишет что у меня нет вип, хотя дни вип аккаунта не закончились. Хотел бы у вас узнать где тут моя ошибка!?
И пожалуйста, если не трудно то с объяснениями так как хочу в будущим не допускать таких ошибок!

Выдача вип аккаунта:

Спойлер

if(!(1 < days < 365)) return SendClientMessage(playerid, COLOR_LIGHTRED, "Не больше 365 и не меньше 1 дня(ей)!");
PlayerInfo[playerid][pDonate] -= days*VipCost;
PlayerInfo[playerid][pVip] = 1;
format(stringEA,sizeof(stringEA),"INSERT INTO `vips` (`Nick`, `UnVipDate`, `VipDate`, ) VALUES ('%s',NOW() + INTERVAL %d DAY, NOW())",PlayerInfo[playerid][pName],days);
mysql_tquery(mysql_connection, stringEA, "","");

В авторизацию сделал так:

Спойлер

format(stringEA, sizeof(stringEA), "SELECT (UNIX_TIMESTAMP(`UnVipDate`)) AS `time` FROM `vips` WHERE `Nick` = '%s'", PlayerInfo[playerid][pName]);
mysql_tquery(mysql_connection, stringEA, "CheckVip", "d", playerid);

И проверка вот так:

Спойлер

public CheckVip(playerid)
{
new stringEA[200];
new time;
if(time-gettime() < 0)
{
format(stringEA, sizeof(stringEA), "DELETE FROM `vips` WHERE `Nick` = '%s'",PlayerInfo[playerid][pName]);
mysql_tquery(mysql_connection, stringEA, "","");
PlayerInfo[playerid][pVip] = 0;
ShowPlayerDialog(playerid,11111,DIALOG_STYLE_MSGBO X,"{FFFFFF}Внимание!","{FFFFFF}Время вашего VIP аккаунта истекло!\nВипка была снята!","Хорошо","");
return true;
}
else
{
format(stringEA, sizeof(stringEA), "\
{FFFFFF}Добро пожаловать VIP игрок!\n\
Дата выдачи VIP: %s\n\
Дата снятия VIP: %s");
ShowPlayerDialog(playerid,11111,DIALOG_STYLE_MSGBO X,"{FFFFFF}Внимание!",stringEA,"Хорошо","");
}
return true;
}

В интернете искал, но не чего не нашёл про mysql r41-2 а переходить на другую версию, иза одной только проблемы... Думаю это очень глупа. 

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

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


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

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

  • 0

Проблема решена, была проблема  в запросе. Решил переписал бд сделал новый запрос, сделал новый паблик checkvip и тд... За место проверки на дату точнее UnVipDate, сделал Таймер gettime() + (60*60*24*days)  и все это сохранил. 

Использовал для проверки работы printf("%d", time);
 

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

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


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

@Покемон Не знаю где вы такой замороченный код достали, если не понимаете, лучше делать полегче. 

Выводите значение переменной time через printf.

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


Ссылка на сообщение
  • 0
2 минуты назад, DEST сказал:

@Покемон Не знаю где вы такой замороченный код достали, если не понимаете, лучше делать полегче. 

Выводите значение переменной time через printf.

 

У меня та же проблема. Не получилось сделать. Может где то на вашем форуме есть такой скрипт?

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


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

@Сергей Князев скрипт чего? Клавиатуры? Нужно в паблике CheckVip 4 строкой добавить:
 

printf("%d", time);

После вызвать этот код заходом в игру и скинуть логи. 

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


Ссылка на сообщение
  • 0
19 минут назад, DEST сказал:

@Сергей Князев скрипт чего? Клавиатуры? Нужно в паблике CheckVip 4 строкой добавить:
 


printf("%d", time);

После вызвать этот код заходом в игру и скинуть логи. 

По пробовал, не чего не написало не загружается, скорее всего в запросе допустил ошибку. Можешь помочь её решить?
Я просто не знаю как использовать загрузку даты в Mysql. ( 

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


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

@Покемон значит смотри в mysql_log.txt и проверяй в базе данных, изменяется значение при выдаче випки

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


Ссылка на сообщение
  • 0
Только что, DEST сказал:

@Покемон значит смотри в mysql_log.txt и проверяй в базе данных, изменяется значение при выдаче випки

Там все правильно, в том то и  дело что при загрузки вип аккаунта проблемы ( 

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


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

@Покемон значит попробуй заменить запрос:

format(stringEA, sizeof(stringEA), "SELECT * FROM `vips` WHERE `Nick` = '%s'", PlayerInfo[playerid][pName]);

И паблик заменить: 

public CheckVip(playerid)
{
  new stringEA[200];
  new time = cache_get_field_content_int(0, "UnVipDate");
  new vipdate = cache_get_field_content_int(0, "VipDate"); 
  if(time-gettime() < 0)
  {
    format(stringEA, sizeof(stringEA), "DELETE FROM `vips` WHERE `Nick` = '%s'",PlayerInfo[playerid][pName]);
    mysql_tquery(mysql_connection, stringEA, "","");
    PlayerInfo[playerid][pVip] = 0;
    ShowPlayerDialog(playerid,11111,DIALOG_STYLE_MSGBO X,"{FFFFFF}Внимание!","{FFFFFF}Время вашего VIP аккаунта истекло!\nВипка была снята!","Хорошо","");
    return true;
  }
  else
  {
    format(stringEA, sizeof(stringEA), "\
    {FFFFFF}Добро пожаловать VIP игрок!\n\
    Дата выдачи VIP: %s\n\
    Дата снятия VIP: %s", date("dd.mm.yyyy, %hh:%ii:%ss", vipdate), date("dd.mm.yyyy, %hh:%ii:%ss", time));
    ShowPlayerDialog(playerid,11111,DIALOG_STYLE_MSGBO X,"{FFFFFF}Внимание!",stringEA,"Хорошо","");
  }
  return true;
}

 

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


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

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

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

    • Mister Odin
      От Mister Odin
       
      new
       g_teleport_list[39][E_TELEPORT_LIST] = {  {"Спавн пгт.Батырево", 1802.3612, 2508.4824, 15.8887},  {"Спавн г.Арзамас", -113.5887, 977.7222, 12.0346},     {"Спавн г.Южный", 2744.2770, -2446.7246, 21.8988},     {"Центральный банк", 1852.020385,2040.791381,15.892713},  {"Рублёвка", -837.7783, 888.6161, 12.7232},  {"Казино", 1332.4252, 2358.7014, 17.6641},  {"Битва за контейнеры", 614.5167, 1722.3566, 12.0709},  {"Автосалон низкого класса", 2493.9616, -722.9544, 12.3315},  {"Автосалон среднего класса", 1407.7449, 455.4801, 13.1630},  {"Автосалон высокого класса", -14.0637, 2614.5664, 10.9892},   {"Мотосалон Harley Davidson", 785.720153, 750.465087, 12.000024},  {"Автошкола", 1909.174438,2227.679687,15.708162},  {"Военкомат", 1916.778564,2302.411376,15.574637},  {"Правительство области", -139.140975,593.789611,12.145712},  {"Отдел полиции №1 (ГИБДД)", 1906.805786,-2234.382812,11.257631},  {"Отдел полиции №2 (УМВД)", 2581.309326,-2416.139892,21.960090},  {"Отдел ФСБ", 1823.904663,2095.636718,15.848405},  {"Городская больница г.Арзамас", -285.797210,581.851562,12.120290},   {"СМИ", -317.708038,821.221679,13.051450},  {"Воинская часть", 1703.197265,1678.025878,15.279437},  {"Арзамасская ОПГ", 438.705322,1046.505126,12.002637},  {"Батыревская ОПГ", 1941.203857,2161.006591,15.705187},  {"Лыткаринская ОПГ", -2346.002441,75.257041,21.002962},  {"Шахта", 2381.5727, 1726.4451, -2.1506},  {"Завод", -1062.6697, 2204.1894, 38.0964},  {"Инкосация", 1864.1374, 2011.7136, 15.8546},  {"Транспортная Компания", 2362.1115, 1972.5627, 15.5530},  {"База механиков", 1840.918090,-118.025146,15.695312},  {"Курьерская служба доставки", 2764.509765,-2396.882568,21.890625},  {"Аренда автобуса(Южный)", 2771.041992,-2454.780761,21.845964},  {"Аренда автобуса(Арзамас)", -127.487670,943.652648,12.142824},   {"Аренда автобуса(Батырево)", 1798.986328,2529.591552,15.664262},  {"Гоночная трасса", -1568.7784, 1611.8305, 36.3971},  {"Дом на горе", -789.5397, -456.7479, 741.1422},  {"СТО и тюнинг-ателье", 1856.1375, -122.3266, 15.6888},  {"Аренда транспорта пгт.Батырево", 1763.641723,2255.673339,15.865348},  {"Аренда транспорта г.Арзамас", -36.923530,1360.673583,12.002090},  {"Аренда транспорта г.Южный", 1966.599975,-2603.943603,10.820312},  {"Тайный интерьер в Лыткарино", -2424.5818, 2846.3291, 40.7908} };