• 0
Умелец

Проблема с сохранением в БД

Вопросы

Всех с праздником, прошу помощи так как моих сил не хватает, проблема заключается в том что не могу сделать обновление в базе данных, то есть у меня есть переменная <pSkin> в которой хранится скин игрока, во время регистрации он подбирает себе нужный скин который должен обновится в Базе данных, но по какой то причине он не обновляется.

Логи пустые

 

 

Спойлер

public OnPlayerClickTextDraw(playerid, Text:clickedid)
{
	if(clickedid == PublicTD[2])// Кнопка Select
	{
		for(new i; i < sizeof(PublicTD); i++) TextDrawHideForPlayer(playerid,PublicTD[i]);
		CancelSelectTextDraw(playerid);
		pInfo[playerid][pSkin] = GetPlayerSkin(playerid);
		SetSpawnInfo(playerid, 0, pInfo[playerid][pSkin], 1, 1, 1, 1, 0, 0, 0, 0, 0, 0);
		SetPlayerVirtualWorld(playerid,0);
		SetPlayerInterior(playerid, 0);
		SpawnPlayer(playerid);
		ChoiceClothes[playerid]=0;
		new sql_query[128];
		format(sql_query, sizeof(sql_query), "UPDATE `accounts` SET `skin` = '%d' WHERE `id` = '%d'", pInfo[playerid][pSkin], pInfo[playerid][pId]);
		mysql_query(dbHandle, sql_query);
	}
}

 

 

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


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

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

  • 0

Огромное спасибо всем кто помогал, проблема в том что регистрация у меня на диалогах, а выбор скина у меня на текстдравах, и вот получается что данные я записывал после регистрации, а скин обновлял уже после нажатия на текстдрав,вот и присваивалось значение 0 так как ID скина еще не было в переменной, еще раз всем спасибо :D

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

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


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

@Умелец, ну, выведем отформатированный SQL-запрос в чат да посмотрим, все ли указанные в нем данные принимают необходимые значения.

public OnPlayerClickTextDraw(playerid, Text:clickedid)
{
	if(clickedid == PublicTD[2])// Кнопка Select
	{
		SendClientMessage(playerid, -1, "OnPlayerClickTextDraw:PublicTD[2]: start");
		for(new i; i < sizeof(PublicTD); i++) TextDrawHideForPlayer(playerid,PublicTD[i]);
		CancelSelectTextDraw(playerid);
		pInfo[playerid][pSkin] = GetPlayerSkin(playerid);
		SetSpawnInfo(playerid, 0, pInfo[playerid][pSkin], 1, 1, 1, 1, 0, 0, 0, 0, 0, 0);
		SetPlayerVirtualWorld(playerid,0);
		SetPlayerInterior(playerid, 0);
		SpawnPlayer(playerid);
		ChoiceClothes[playerid]=0;
		new sql_query[128];
		format(sql_query, sizeof(sql_query), "UPDATE `accounts` SET `skin` = '%d' WHERE `id` = '%d'", pInfo[playerid][pSkin], pInfo[playerid][pId]);
		mysql_query(dbHandle, sql_query);
		SendClientMessage(playerid, -1, sql_query)
		SendClientMessage(playerid, -1, "OnPlayerClickTextDraw:PublicTD[2]: end");
	}
}

 

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


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

@odosenokЧто-то здесь явно не так

 

  Screenshot_62.png.c703ba5b5ddbaf3e665e059f8799746d.pngScreenshot_63.png.11d12db0a126512dffdae201a9338aa0.png

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

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


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

Не увидел SetPlayerSkin, проблема только из-за этого. Ты не выдаёшь скин игроку стандартной функцией, и сохраняешь в ячейку значение 0.

UDP: Посмотри ещё структуру таблицы, стоит ли у тебя int на этот столбик.

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

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


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

@Умелец, меня интересует не `id`, а `skin`. Покажи ещё mysql_log.txt

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


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

@glvde. Логи  пустыеScreenshot_65.png.4355ad88ff8f301073d4735f29b695b3.png

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


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

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

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

    • Узбек
      От Узбек
      Всем добрый вечер ребят! 
      Я начинающий, сегодня я вам сливаю команду 2(шт) на технические работы
      Ловите 
       
    • nazpol9
      От nazpol9
      Привет всем.

      У меня имеется мод для самп сервера и VPS с Ubuntu, на котором я пытаюсь его запустить.

      В чем суть проблемы: при запуске samp03svr, сервер запускается, но на версии 0.3.DL R-1. Когда я пытаюсь запустить этот же мод локально на Windows, сервер работает на версии 0.3.7 и я могу зайти на него без клиента 0.3.DL.

      Для решения этой проблемы я уже пробовал заменять инклуды и исполнительные файлы теми, что есть в архивах на официальном сайте сампа, перекомпилировал мод, и ничего не изменилось.
       
      #include <a_samp> #include <a_mysql> #include <foreach> #include <Pawn.RakNet> #include <streamer> #include <sscanf2> #include <float2> #include <crashdetect> #include <fmt> #include <a_http> #include <Pawn.CMD> #include <Pawn.Regex> #include <requests> #include <callbacks> #include <MD5> #include <mxdate> #include <TOTP> #include <gvar> #include <md-sort> #include <nex-ac> #include <weapon-config> #include <discord-connector> #include <3DTryg> #include <textdraw-streamer>  
      plugins crashdetect.so streamer.so textdraw-streamer.so sscanf.so pawnraknet.so pawncmd.so mysql.so requests.so profiler.so pawnregex.so TOTP.so gvar.so discord-connector.so

      Если у кого-то будут какие-либо догадки, прошу ими поделиться, если понадобится больше информации - я постараюсь её предоставить.