• 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 пользователей онлайн

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

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

    • Артём Профиков
      От Артём Профиков
      У меня есть система подсказок вот так она выглядет
      ShowNotification(playerid, тип, "текст", время, "команда через /", "текст кнопки");
      Только есть вопрос как сделать так чтоб она активировалась в определенном радиусе? Заранее спасибо