Вопросы

покупаю через донат все скилли, перехожу на сервер снова 0% вот код 
 

Спойлер

		case D_DONATE+4:
		{
			if(!response) return 1;
			switch(listitem)
			{
              	case 0:
			    {
			        if(PI[playerid][pCredits] < 400) return SendClientMessage(playerid, COLOR_GREY, "Недостаточно кредитов!");
			        PI[playerid][pCredits] -= 400;
					MysqlUpdatePlayerInt(playerid, "credits", PI[playerid][pCredits]);
			        for(new i; i < 8; i++) g_player_skills[playerid][S_GUN][i] = 100;
					SendClientMessage(playerid, COLOR_LIME, "Вы приобрели все навыки владения оружием!");
					SavePlayerSkills(playerid);

 

 

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


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

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

  • 0

@Drummer1993  И так, подумав и раздумав, решили проблему. Она была в том что каждый раз, в OnPlayerLogin, вызывался SavePlayerSkills(playerid);, из за этого сразу же загружались в бд дефолтные данные. Переместив его в LoadPlayerSkills(playerid), тобишь в загрузку скиллов, все заработало как нужно. То есть, теперь загружаются данные которые, из базы данных.

Цитата

public: LoadPlayerSkills(playerid)
{
	new rows, fields, buffer[64];
    cache_get_data(rows, fields);
    if(rows)
	{
		cache_get_field_content(0, "drive", buffer, dbHandle, 64);
		
		sscanf
		(
			buffer, "p<,>dddd",
			g_player_skills[playerid][S_LICS][0], 
			g_player_skills[playerid][S_LICS][1], 
			g_player_skills[playerid][S_LICS][2], 
			g_player_skills[playerid][S_LICS][3]
		);
		
		cache_get_field_content(0, "gun", buffer, dbHandle, 64);
		
		sscanf
		(
			buffer, "p<,>dddddddd", 
			g_player_skills[playerid][S_GUN][0], 
			g_player_skills[playerid][S_GUN][1], 
			g_player_skills[playerid][S_GUN][2], 
			g_player_skills[playerid][S_GUN][3],
			g_player_skills[playerid][S_GUN][4], 
			g_player_skills[playerid][S_GUN][5], 
			g_player_skills[playerid][S_GUN][6], 
			g_player_skills[playerid][S_GUN][7]
		);
		
		SetPlayerSkillData(playerid, S_T_FLIGHTS, cache_get_field_content_int(0, "t_flights"));
		SetPlayerSkillData(playerid, S_T_COUNT, cache_get_field_content_int(0, "t_count"));
		SetPlayerSkillData(playerid, S_TAXI_CALLS, cache_get_field_content_int(0, "taxi_calls"));
		SetPlayerSkillData(playerid, S_M_FIX, cache_get_field_content_int(0, "m_fix"));
		SetPlayerSkillData(playerid, S_B_FLIGHTS, cache_get_field_content_int(0, "b_flights"));
		SetPlayerSkillData(playerid, S_PILOT_LVL, cache_get_field_content_int(0, "pilot_lvl"));
		SetPlayerSkillData(playerid, S_PILOT_RACE, cache_get_field_content_int(0, "pilot_race"));
		
		SetPlayerSkillLevel(playerid, WEAPONSKILL_PISTOL_SILENCED, 		g_player_skills[playerid][S_GUN][0]*10);
		SetPlayerSkillLevel(playerid, WEAPONSKILL_DESERT_EAGLE, 		g_player_skills[playerid][S_GUN][1]*10);
		SetPlayerSkillLevel(playerid, WEAPONSKILL_SHOTGUN, 				g_player_skills[playerid][S_GUN][2]*10);
		SetPlayerSkillLevel(playerid, WEAPONSKILL_MP5, 					g_player_skills[playerid][S_GUN][3]*10);
		SetPlayerSkillLevel(playerid, WEAPONSKILL_AK47, 				g_player_skills[playerid][S_GUN][4]*10);
		SetPlayerSkillLevel(playerid, WEAPONSKILL_M4, 					g_player_skills[playerid][S_GUN][5]*10);
		SetPlayerSkillLevel(playerid, WEAPONSKILL_PISTOL, 				g_player_skills[playerid][S_GUN][6]*10);
		SetPlayerSkillLevel(playerid, WEAPONSKILL_MICRO_UZI, 			g_player_skills[playerid][S_GUN][7]*10);
		SavePlayerSkills(playerid); // Вот добавление.

 

 

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


Ссылка на сообщение
  • 0
SavePlayerSkills в студию

и mysql_log

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


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

SavePlayerSkills в студию

и mysql_log

Спойлер

stock SetPlayerSkills(playerid)
{
	SetPlayerSkillLevel(playerid, WEAPONSKILL_PISTOL_SILENCED, 		g_player_skills[playerid][S_GUN][0]*10);
	SetPlayerSkillLevel(playerid, WEAPONSKILL_DESERT_EAGLE, 		g_player_skills[playerid][S_GUN][1]*10);
	SetPlayerSkillLevel(playerid, WEAPONSKILL_SHOTGUN, 				g_player_skills[playerid][S_GUN][2]*10);
	SetPlayerSkillLevel(playerid, WEAPONSKILL_MP5, 					g_player_skills[playerid][S_GUN][3]*10);
	SetPlayerSkillLevel(playerid, WEAPONSKILL_AK47, 				g_player_skills[playerid][S_GUN][4]*10);
	SetPlayerSkillLevel(playerid, WEAPONSKILL_M4, 					g_player_skills[playerid][S_GUN][5]*10);
	SetPlayerSkillLevel(playerid, WEAPONSKILL_PISTOL, 				g_player_skills[playerid][S_GUN][6]*10);
	SetPlayerSkillLevel(playerid, WEAPONSKILL_MICRO_UZI, 			g_player_skills[playerid][S_GUN][7]*10);
	SavePlayerSkills(playerid);
	return 1;
Спойлер


stock SavePlayerSkills(playerid)
{	
	STRING_GLOBAL[0] = EOS;
	
	format
	(
		STRING_GLOBAL, sizeof STRING_GLOBAL,
		"UPDATE accounts_skills SET drive='%d, %d, %d, %d', gun='%d, %d, %d, %d, %d, %d, %d, %d', t_flights=%d, t_count=%d, taxi_calls=%d, m_fix=%d, b_flights=%d WHERE owner=%d",
		g_player_skills[playerid][S_LICS][0],
		g_player_skills[playerid][S_LICS][1],
		g_player_skills[playerid][S_LICS][2],
		g_player_skills[playerid][S_LICS][3],
		g_player_skills[playerid][S_GUN][0], 
		g_player_skills[playerid][S_GUN][1], 
		g_player_skills[playerid][S_GUN][2], 
		g_player_skills[playerid][S_GUN][3], 
		g_player_skills[playerid][S_GUN][4], 
		g_player_skills[playerid][S_GUN][5], 
		g_player_skills[playerid][S_GUN][6], 
		g_player_skills[playerid][S_GUN][7],
		g_player_skills[playerid][S_T_FLIGHTS],
		g_player_skills[playerid][S_T_COUNT],
		g_player_skills[playerid][S_TAXI_CALLS],
		g_player_skills[playerid][S_M_FIX],
		g_player_skills[playerid][S_B_FLIGHTS],
		PI[playerid][pID]
	);
	mysql_tquery(dbHandle, STRING_GLOBAL);
Спойлер



[17:57:45] [ERROR] CMySQLQuery::Execute[] - (error #1054) Unknown column 'mafia' in 'field list'
[17:57:45] [ERROR] CMySQLQuery::Execute[] - (error #1054) Unknown column 'mafia' in 'field list'
[17:57:45] [ERROR] CMySQLQuery::Execute[] - (error #1054) Unknown column 'mafia' in 'field list'
[17:57:45] [ERROR] CMySQLQuery::Execute[] - (error #1054) Unknown column 'mafia' in 'field list'
[17:57:45] [ERROR] CMySQLQuery::Execute[] - (error #1054) Unknown column 'mafia' in 'field list'
[17:57:45] [ERROR] CMySQLQuery::Execute[] - (error #1054) Unknown column 'mafia' in 'field list'
[17:57:45] [ERROR] CMySQLQuery::Execute[] - (error #1054) Unknown column 'mafia' in 'field list'
[17:57:45] [ERROR] CMySQLQuery::Execute[] - (error #1054) Unknown column 'mafia' in 'field list'
[17:57:45] [ERROR] CMySQLQuery::Execute[] - (error #1054) Unknown column 'mafia' in 'field list'
[17:57:45] [ERROR] CMySQLQuery::Execute[] - (error #1054) Unknown column 'mafia' in 'field list'

 

 

 

 

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


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

@Drummer1993 Логи mysql_log.txt  можно? 

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


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

@Drummer1993 Логи mysql_log.txt  можно? 

Спойлер

[17:57:45] [ERROR] CMySQLQuery::Execute[] - (error #1054) Unknown column 'mafia' in 'field list'
[17:57:45] [ERROR] CMySQLQuery::Execute[] - (error #1054) Unknown column 'mafia' in 'field list'
[17:57:45] [ERROR] CMySQLQuery::Execute[] - (error #1054) Unknown column 'mafia' in 'field list'
[17:57:45] [ERROR] CMySQLQuery::Execute[] - (error #1054) Unknown column 'mafia' in 'field list'
[17:57:45] [ERROR] CMySQLQuery::Execute[] - (error #1054) Unknown column 'mafia' in 'field list'
[17:57:45] [ERROR] CMySQLQuery::Execute[] - (error #1054) Unknown column 'mafia' in 'field list'
[17:57:45] [ERROR] CMySQLQuery::Execute[] - (error #1054) Unknown column 'mafia' in 'field list'
[17:57:45] [ERROR] CMySQLQuery::Execute[] - (error #1054) Unknown column 'mafia' in 'field list'
[17:57:45] [ERROR] CMySQLQuery::Execute[] - (error #1054) Unknown column 'mafia' in 'field list'
[17:57:45] [ERROR] CMySQLQuery::Execute[] - (error #1054) Unknown column 'mafia' in 'field list'

 

 

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


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

SetPlayerSkillLevel давай

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


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

SetPlayerSkillLevel давай

у меня в моде нет такого вообще SetPlayerSkillLevel , я скинул вам больше не чего нет

SetPlayerSkills,
SavePlayerSkills

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


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

@SCRIPTMAN А не должен разве идти запрос в бд, что-бы их сохранить после покупки скиллов? Лично у меня после покупки идет запрос, хоть в покупке, или в ежедневнем бонусе.

 

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

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


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

@Drummer1993 извиняюсь, это стандартная функция

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


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

@Drummer1993 Будьте добры, скинуть callback загрузки аккаунта.

 

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


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

А покажи-ка таблицу "accounts_skills", можно скрином, её структуру, или даже запись

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


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

@SCRIPTMAN А не должен разве идти запрос в бд, что-бы их сохранить после покупки скиллов? Лично у меня после покупки идет запрос, хоть в покупке, или в ежедневнем бонусе.

 

Спойлер

--
-- Структура таблицы `accounts_skills`
--

CREATE TABLE IF NOT EXISTS `accounts_skills` (
  `owner` int(11) NOT NULL DEFAULT '-1',
  `drive` varchar(16) NOT NULL DEFAULT '0, 0, 0, 0',
  `gun` varchar(64) NOT NULL DEFAULT '0, 0, 0, 0, 0, 0, 0, 0',
  `t_flights` int(11) NOT NULL DEFAULT '0',
  `t_count` int(11) NOT NULL DEFAULT '0',
  `taxi_calls` int(11) NOT NULL DEFAULT '0',
  `m_fix` int(11) NOT NULL DEFAULT '0',
  `b_flights` int(11) NOT NULL DEFAULT '0',
  `pilot_lvl` int(11) NOT NULL DEFAULT '0',
  `pilot_race` int(11) NOT NULL DEFAULT '0'
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;

--
-- Дамп данных таблицы `accounts_skills`
--

INSERT INTO `accounts_skills` (`owner`, `drive`, `gun`, `t_flights`, `t_count`, `taxi_calls`, `m_fix`, `b_flights`, `pilot_lvl`, `pilot_race`) VALUES
(0, '1, 1, 1, 1', '0, 0, 0, 0, 0, 0, 0, 0', 0, 0, 0, 0, 0, 0, 0),

 

 

4 минуты назад, SCRIPTMAN сказал:

А покажи-ка таблицу "accounts_skills", можно скрином, её структуру, или даже запись

Спойлер

--
-- Структура таблицы `accounts_skills`
--

CREATE TABLE IF NOT EXISTS `accounts_skills` (
  `owner` int(11) NOT NULL DEFAULT '-1',
  `drive` varchar(16) NOT NULL DEFAULT '0, 0, 0, 0',
  `gun` varchar(64) NOT NULL DEFAULT '0, 0, 0, 0, 0, 0, 0, 0',
  `t_flights` int(11) NOT NULL DEFAULT '0',
  `t_count` int(11) NOT NULL DEFAULT '0',
  `taxi_calls` int(11) NOT NULL DEFAULT '0',
  `m_fix` int(11) NOT NULL DEFAULT '0',
  `b_flights` int(11) NOT NULL DEFAULT '0',
  `pilot_lvl` int(11) NOT NULL DEFAULT '0',
  `pilot_race` int(11) NOT NULL DEFAULT '0'
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;

--
-- Дамп данных таблицы `accounts_skills`
--

INSERT INTO `accounts_skills` (`owner`, `drive`, `gun`, `t_flights`, `t_count`, `taxi_calls`, `m_fix`, `b_flights`, `pilot_lvl`, `pilot_race`) VALUES
(0, '1, 1, 1, 1', '0, 0, 0, 0, 0, 0, 0, 0', 0, 0, 0, 0, 0, 0, 0),

 

 

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


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

В базе не смотрел. сохраняется всё?

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


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

В базе не смотрел. сохраняется всё?

по началу да .. как только снова захожу снова 0.0.0.0.0.

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


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

@Drummer1993 Я думаю это нужно вставить, после покупки скиллов не? Ну под себя настройте.

Цитата

new query_string [ 148 ] ;
format ( query_string, sizeof ( query_string ),"UPDATE `accounts_skills` SET `gun`='100,100,100,100,100,100,100' WHERE `owner` = '%d' LIMIT 1",
GetPlayerName(playerid, PI[playerid] [name], MAX_PLAYER_NAME)) ;
mysql_query ( sql_connection, query_string ) 

 

 

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


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

@Drummer1993 Я думаю это нужно вставить, после покупки скиллов не? Ну под себя настройте.

 

Спойлер

case D_DONATE+4:
		{
			if(!response) return 1;
			switch(listitem)
			{
              	case 0:
			    {
			        if(PI[playerid][pCredits] < 400) return SendClientMessage(playerid, COLOR_GREY, "Недостаточно кредитов!");
			        PI[playerid][pCredits] -= 400;
					MysqlUpdatePlayerInt(playerid, "credits", PI[playerid][pCredits]);
			        for(new i; i < 8; i++) g_player_skills[playerid][S_GUN][i] = 100;
					SendClientMessage(playerid, COLOR_LIME, "Вы приобрели все навыки владения оружием!");
					SavePlayerSkills(playerid);

 

 

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


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

@Drummer1993 Да, вот сюда. Только настройте под себя, подключение к бд.

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


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

@Nekit_Krut18 вставлять ничего не нужно, у него для этого там прописан сток SavePlayerSkills,

Сделай вот что:

Включи логирование MySQL (В OnGameModeInit вставь после подключения бд mysql_log(ALL);)

Скомпилируй, потом удали mysql_log, запусти серв, зайди, выдай скиллы, потом выйди, снова зайди, потом скинь логи mysql

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


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

@Nekit_Krut18 вставлять ничего не нужно, у него для этого там прописан сток SavePlayerSkills,

Сделай вот что:

Включи логирование MySQL (В OnGameModeInit вставь после подключения бд mysql_log(ALL);)

Скомпилируй, потом удали mysql_log, запусти серв, зайди, выдай скиллы, потом выйди, снова зайди, потом скинь логи mysql

хорошо 5 минут

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


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

@Nekit_Krut18 вставлять ничего не нужно, у него для этого там прописан сток SavePlayerSkills,

Сделай вот что:

Включи логирование MySQL (В OnGameModeInit вставь после подключения бд mysql_log(ALL);)

Скомпилируй, потом удали mysql_log, запусти серв, зайди, выдай скиллы, потом выйди, снова зайди, потом скинь логи mysql

 error 017: undefined symbol "ALL"

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


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

@Drummer1993 mysql_log(LOG_ALL);

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


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

@Drummer1993 mysql_log(LOG_ALL);

все сейчас зайду куплю скилл и выйду лог скину

16 минут назад, Nekit_Krut18 сказал:

@Drummer1993 mysql_log(LOG_ALL);

 

mysql_log.zip

32 минуты назад, SCRIPTMAN сказал:

@Nekit_Krut18 вставлять ничего не нужно, у него для этого там прописан сток SavePlayerSkills,

Сделай вот что:

Включи логирование MySQL (В OnGameModeInit вставь после подключения бд mysql_log(ALL);)

Скомпилируй, потом удали mysql_log, запусти серв, зайди, выдай скиллы, потом выйди, снова зайди, потом скинь логи mysql

 

mysql_log.zip

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


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

@Drummer1993 Скинь загрузку аккаунта, callback должен быть.

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


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

@Drummer1993 Скинь загрузку аккаунта, callback должен быть.

Спойлер

}

public: callback_show_logs ( playerid )
{
	new rows, fields ;
	cache_get_data ( rows, fields ) ;
	if ( ! rows )
	{
		DeletePVar ( playerid, "ofm_list_page" ) ;
		SendClientMessage(playerid, -1, ""cER"Записей не обнаружено");
		return 1 ;
	}
	new rows_list = GetPVarInt ( playerid, "ofm_list_page" ) - 1 ;
	SetPVarInt ( playerid, "ofm_list_rows", rows ) ;
	new fmt_str [ 150 ],
	text [ 144 ],
	data [ 20 ];

	STRING_GLOBAL[0] = EOS;
	for ( new i = rows_list * 10 ; i <  rows_list * 10 + 10 ; i ++ )
	{
		if ( i >= rows ) break ;

		cache_get_field_content ( i, "text", text, dbHandle, 144 ) ;
		cache_get_field_content ( i, "date", data, dbHandle, 20 ) ;

		format ( fmt_str, sizeof ( fmt_str ), "{bff277}%s - {eaffcc}%s\n", data, text) ;
		strcat ( STRING_GLOBAL, fmt_str ) ;

	}

	ShowPlayerDialog ( playerid, DIALOG_ADMIN_LOGS + 1, DIALOG_STYLE_MSGBOX, "{b6db81}Просмотр логов", STRING_GLOBAL, "Назад", "Вперед" ) ;
	return 1 ;

 

 

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


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

@Drummer1993 Вы не поняли, где происходит загрузка аккаунта, тобишь загружаются данные аккаунта. Какой у вас мод, Perfect? 

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


Ссылка на сообщение
Гость
Эта тема закрыта для публикации ответов.
  • Последние посетители   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} };