Вопросы

danrj3
Новичок

Здравствуйте 
Как создать команду для получение приза с рулетки сайта? Есть таблица с игроками и таблица выигрышами

a4eJEtKS.png

09dSGKCS.png

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


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

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

  • 0
danrj3
Новичок
  В 5/17/2020 в 08:29, iQua сказал:

В .pwn нужно искать команду, а не в базе данных.

Читать далее...  

не, я понимаю.. ее нету вообще. Нужно ка-кто сделать обращение на таблицу, проверки на приз и тп, чтоб игрок мог забрать свой приз (деньги, донат, машину, скин)

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


Ссылка на сообщение
  • 0
Cawfee
Великий Гуру

@danrj3, ну, вот Вам пример.

 

  Код (открыть спойлер)

 

Хотя, как по мне, лучше здесь работать с битами (тот же куш представляет собой совокупность ряда других призов, потому можно не создавать под него отдельный идентификатор, а проверять, проставлены ли все остальные флажки, чтобы понимать, действительно ли это куш).

 

  Код (открыть спойлер)


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

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


Ссылка на сообщение
  • 0
danrj3
Новичок
  В 5/17/2020 в 13:04, odosenok сказал:

@danrj3, ну, вот Вам пример.

 

  Код (открыть спойлер)

 

Хотя, как по мне, лучше здесь работать с битами (тот же куш представляет собой совокупность ряда других призов, потому можно не создавать под него отдельный идентификатор, а проверять, проставлены ли все остальные флажки, чтобы понимать, действительно ли это куш).

 

  Код (открыть спойлер)


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

Читать далее...  

Спасибо, кажется начал понимать. сейчас проверим)

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


Ссылка на сообщение
  • 0
danrj3
Новичок
  В 5/17/2020 в 13:04, odosenok сказал:

@danrj3, ну, вот Вам пример.

 

  Код (открыть спойлер)

 

Хотя, как по мне, лучше здесь работать с битами (тот же куш представляет собой совокупность ряда других призов, потому можно не создавать под него отдельный идентификатор, а проверять, проставлены ли все остальные флажки, чтобы понимать, действительно ли это куш).

 

  Код (открыть спойлер)


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

Читать далее...  

Вот работает, но выдает бесконечно приз

givePrizes(playerid)
{
new string[109+(-2+MAX_PLAYER_NAME)+1];
GetPlayerName(playerid, string, MAX_PLAYER_NAME);
format(string, sizeof(string), "SELECT p_id FROM ucp_drop_roulette WHERE p_user = '%s' AND p_status = 0", string);
mysql_query(dbHandle, string);

new rows = cache_num_rows();
for (new i = 0; i < rows; i++)
{
new prizID = cache_get_field_content_int(i, "p_id");
switch (prizID)
{
case 1:
{
player[playerid][pmoney] += 1000;
SCM(playerid, COLOR_RED, !"[Рулетка Revold]: {B4B4B4}Ваш приз 10000$");
SavePlayer(playerid, "Money", player[playerid][pmoney], "d");
}
case 2:
{
player[playerid][pdonate] += 50;
SCM(playerid, COLOR_RED, !"[Рулетка Revold]: {B4B4B4}Ваш приз 50 руб");
SavePlayer(playerid, "Donate", player[playerid][pdonate], "d");
}
}
}

return rows;
}

Ещё

 

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


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

@danrj3 после того, как приз выдали, p_status нужно выставить в число, не равное 0 (исходя из сформированного запроса) 

  В 5/17/2020 в 21:50, danrj3 сказал:

format(string, sizeof(string), "SELECT p_id FROM ucp_drop_roulette WHERE p_user = '%s' AND p_status = 0", string);

Читать далее...  

 

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


Ссылка на сообщение
  • 0
danrj3
Новичок
  В 5/17/2020 в 22:16, DEST сказал:

@danrj3 после того, как приз выдали, p_status нужно выставить в число, не равное 0 (исходя из сформированного запроса) 

 

Читать далее...  

Да, знаю
пытался "UPDATE", ничего не вышло

format(string, sizeof(string), "UPDATE ucp_drop_roulette SET p_status = 1 WHERE p_user = '%s' AND p_status = 0", string);


 

 

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


Ссылка на сообщение
  • 0
danrj3
Новичок
givePrizes(playerid)
{
  new string[109+(-2+MAX_PLAYER_NAME)+1];
  GetPlayerName(playerid, string, MAX_PLAYER_NAME);
  format(string, sizeof(string), "SELECT p_id FROM ucp_drop_roulette WHERE p_user = '%s' AND p_status = 0", string);
  mysql_query(dbHandle, string);
  new rows = cache_num_rows();
  for (new i = 0; i < rows; i++)
  {
    new prizID = cache_get_field_content_int(i, "p_id");
    switch (prizID)
  {
    case 1:
    {
    player[playerid][pmoney] += 1000;
    SCM(playerid, COLOR_RED, !"[Рулетка Revold]: {B4B4B4}Ваш приз 10000$");
    SavePlayer(playerid, "Money", player[playerid][pmoney], "d");
    format(string, sizeof(string), "UPDATE ucp_drop_roulette SET p_status = 1 WHERE p_user = '%s' AND p_status = 0", string);

    }
    case 2:
    {
    player[playerid][pdonate] += 50;
    SCM(playerid, COLOR_RED, !"[Рулетка Revold]: {B4B4B4}Ваш приз 50 руб");
    SavePlayer(playerid, "Donate", player[playerid][pdonate], "d");
    format(string, sizeof(string), "UPDATE ucp_drop_roulette SET p_status = 1 WHERE p_user = '%s' AND p_status = 0", string);
    }
}
}

return rows;
}

 

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


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

@danrj3 

1. Код обновления статуса можно вынести за цикл, т.к. он выполняется сразу для всех призов, которые есть у игрока (в принципе старайтесь избегать запросов к базе в цикле). 

2. После форматирования запроса (записи его в переменную string) необходимо его отправить в базу, с помощью функции mysql_query. 

3. В параметрах форматирования использована переменная string, в которую до этого с помощью format записан запрос на отображение данных. Заведите разные переменные: одну под запрос, другую под ник игрока. 

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


Ссылка на сообщение
  • 0
danrj3
Новичок
  В 5/18/2020 в 11:35, DEST сказал:

@danrj3 

1. Код обновления статуса можно вынести за цикл, т.к. он выполняется сразу для всех призов, которые есть у игрока (в принципе старайтесь избегать запросов к базе в цикле). 

2. После форматирования запроса (записи его в переменную string) необходимо его отправить в базу, с помощью функции mysql_query. 

3. В параметрах форматирования использована переменная string, в которую до этого с помощью format записан запрос на отображение данных. Заведите разные переменные: одну под запрос, другую под ник игрока. 

Читать далее...  

Что-то ничего не выходит(

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


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

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

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

    • Danya_Smolin
      От Danya_Smolin

      Что добавили в доработку мода страйк:
      1. Викторина
      2. Новый вокзал
      3. Аренда мопедов по пикапу
      4. Система грандиозного пропуска (Батл-пасс)
      5. Система подарков
      6. Премиум аккаунт
      7. Эксклюзивные автомобили
      8. Добавили очень много команд для администраторов
      9. Новое окно авторизации

      10. Новая система бизнесов

      11. Добавили команду /fixcar
      12. Система военного положения
      13. Система аварии на зоне-51

      14. Система подкупного полицейского

      15. Новый логотип
      16. Добавили много новых аксессуаров
      17. Добавили таймер в виде TextDraws.

      18. Музыка при регистрации и на вокзале
      19. Добавили маппинг КПП и домиков на дереве

      20. Исправили множество багов

      21. Добавили сертификаты

      22. Добавили навыки

      23. Добавили рынок барыг

      24. Добавили инвесторов
      25. Добавили 5 новых мест в /gps

      26. Добавили обучение персонажа

      27. Новые интерьеры
      28. Добавили админские команды

      29. Система контейнеров

      30. Система создания семей

      31. Система сертификатов

      32. Система кейсов
      33. Добавили челлендж на донат-рубли

      34. Добавили маппинг на пляже

      35. Добавили команды для мероприятия

      36. Добавили новые банкоматы

      37. Добавили команду /anticheat

      38. Добавили команду /veh

      39. Система барыг

      40. Система инвесторов

      41. Добавили систему привилегий

      42. Добавили новый магазин для выгодных покупок только для привилегий - /pdonate
      43. Переписан /donaterub.

      44. Добавлено 13 костюмов.

      45. Исправлена база данных.

      46. Исправлены мелкие баги.

      47. Добавлено 17 титулов.

      48. Исправлен /donaterub.

      49. Теперь эксклюзивные машины сохраняются после выхода.

      50. Ваши мани теперь под защитой и их не украдут мошенники после перезахода.

      51. Скин сохраняется после выхода/перезахода.

      52. Донат/Деньги/Уровень сохраняется после перезахода.

      53. Исправлены ошибки в БД.
    • Danya_Smolin
      От Danya_Smolin
      Cтрайк Рп
      Скачать файл
      Что добавили в доработку мода страйк:
      1. Викторина
      2. Новый вокзал
      3. Аренда мопедов по пикапу
      4. Система грандиозного пропуска (Батл-пасс)
      5. Система подарков
      6. Премиум аккаунт
      7. Эксклюзивные автомобили
      8. Добавили очень много команд для администраторов
      9. Новое окно авторизации

      10. Новая система бизнесов

      11. Добавили команду /fixcar
      12. Система военного положения
      13. Система аварии на зоне-51

      14. Система подкупного полицейского

      15. Новый логотип
      16. Добавили много новых аксессуаров
      17. Добавили таймер в виде TextDraws.

      18. Музыка при регистрации и на вокзале
      19. Добавили маппинг КПП и домиков на дереве

      20. Исправили множество багов

      21. Добавили сертификаты

      22. Добавили навыки

      23. Добавили рынок барыг

      24. Добавили инвесторов
      25. Добавили 5 новых мест в /gps

      26. Добавили обучение персонажа

      27. Новые интерьеры
      28. Добавили админские команды

      29. Система контейнеров

      30. Система создания семей

      31. Система сертификатов

      32. Система кейсов
      33. Добавили челлендж на донат-рубли

      34. Добавили маппинг на пляже

      35. Добавили команды для мероприятия

      36. Добавили новые банкоматы

      37. Добавили команду /anticheat

      38. Добавили команду /veh

      39. Система барыг

      40. Система инвесторов

      41. Добавили систему привилегий

      42. Добавили новый магазин для выгодных покупок только для привилегий - /pdonate
      43. Переписан /donaterub.

      44. Добавлено 13 костюмов.

      45. Исправлена база данных.

      46. Исправлены мелкие баги.

      47. Добавлено 17 титулов.

      48. Исправлен /donaterub.

      49. Теперь эксклюзивные машины сохраняются после выхода.

      50. Ваши мани теперь под защитой и их не украдут мошенники после перезахода.

      51. Скин сохраняется после выхода/перезахода.

      52. Донат/Деньги/Уровень сохраняется после перезахода.

      53. Исправлены ошибки в БД.
      Добавил Danya_Smolin Добавлено 07.07.2025 Категория Моды Автор Pwn_Admin  
    • OREGON-RPG
      От OREGON-RPG
      **Привет, будущий друг!**
      Мы создаем новый сервер в >> GTA SA-MP (OregoN Role Playing Game) << и ищем таких же увлеченных игроков, как ты!!!

      Здесь ты сможешь: 

      Влиять на развитие сервера – твое мнение важно! 

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

      Сервер еще в разработке – это шанс войти в историю с самого начала! 

       >>> Давай строить этот мир вместе? <<<

       Переходи по ссылке, будь в центре событий и стань частью истории: 

      [ Группа ВКонтакте: vk.com/oregonrpgru ]

      [ Форум: oregon-rpg.ru ]
    • Binggus
      От Binggus
      Пишет: "non.p(0) : fatal error 100: cannot read from file: "non.p"

      Compilation aborted.

      Pawn compiler 3.2.3664        Copyright (c) 1997-2017, ITB CompuPhase


      1 Error."
       
      Сборка:
      https://cloud.mail.ru/public/eGyt/6hFRdRK1m