Вопросы

Спойлер

stock SaveGifts(playerid)
{
    new str[MAX_GIFTS*2];
	for(new i; i < MAX_GIFTS; i++)
	{
		if(i+1 == MAX_GIFTS) {
			 format(str, sizeof str, "%s%d",str, PI[playerid][pPrize][i]);
			 break;
		}
		format(str, sizeof str, "%s%d,", str, PI[playerid][pPrize][i]);
	}
	mysql_format(dbHandle, STRING_GLOBAL, sizeof str, "UPDATE "T_ACCOUNTS" SET `gifts` = `%s` WHERE `name` = '%s'", str, PI[playerid][pName]);
	mysql_function_query(dbHandle, STRING_GLOBAL, false, "", "");
	printf("%s - query, %s - name", STRING_GLOBAL, PI[playerid][pName]);
	return 1;
}
stock LoadPodarok()
{
	new TOTALGIFTS;
	new time = GetTickCount();
	for(new i; i < sizeof(PODAROK_CORD); i++)
	{
        gift_pick[i] = CreatePickup(19056,1, PODAROK_CORD[i][ppX], PODAROK_CORD[i][ppY], PODAROK_CORD[i][ppZ]);
		TOTALGIFTS++;
	}
	print("############### Система подарков загружена! ###############");
	printf("$ Кол-во загруженных подарков: %d штук из %d возможных    $", TOTALGIFTS, MAX_GIFTS);
	printf("$ Скорость загрузки: %d миллисекунд                       $", GetTickCount()-time);
	printf("###########################################################");
	return true;
}

 

 

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


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

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

  • 0

@archiboy6 а где они должны сохранятся?

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


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

@User Shokolad они должны в базу сохранится, чтобы после перезахода/рестарта игрокам заного собирать не пришлось P.S Система делал DEST

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


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

@archiboy6, ну, покажите mysql_log.

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


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

@odosenok 

[16:45:26] [ERROR] CMySQLQuery::Execute[] - (error #1054) Unknown column '1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,' in 'field list' 
[16:45:30] [ERROR] CMySQLQuery::Execute[] - (error #1054) Unknown column '1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,' in 'field list' 
[16:47:17] [ERROR] CMySQLQuery::Execute[] - (error #1054) Unknown column '1,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,' in 'field list'
Спойлер

stock SaveGifts(playerid)
{
	new str[MAX_GIFTS*2];
	for(new i; i < MAX_GIFTS; i++)
	{
	if(i+1 == MAX_GIFTS) {
	format(str, sizeof str, "%s%d",str, PI[playerid][pPrize][i]);
	break;
	}
	format(str, sizeof str, "%s%d,", str, PI[playerid][pPrize][i]);
	}
	new stra[600];
	format(stra,sizeof(stra), "UPDATE `accounts` SET `gifts` = `%s` WHERE `name` = '%s'", str, PI[playerid][pName]);
	mysql_function_query(dbHandle, stra, false, "", "");
	printf("%s - query, %s - name", stra, PI[playerid][pName]);
	return 1;
}

 

 

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


Ссылка на сообщение
  • 0
3 часа назад, archiboy6 сказал:

@odosenok 

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


format(stra,sizeof(stra), "UPDATE `accounts` SET `gifts` = `%s` WHERE `name` = '%s'", str, PI[playerid][pName]);

 

 

 

Попробуйте вот так сделать:

format(stra,sizeof(stra), "UPDATE `accounts` SET `gifts` = '%s' WHERE `name` = '%s'", str, PI[playerid][pName]);

Потому что названия столбцов, таблиц следует заключать в тильды (`), а сами значения в апострофы ('). У вас же текст (%s) был заключен в тильды, что не есть правильно. По сути база данных пыталась к столбцу gifts приравнять столбец, название которого состоит из кучи нулей (эти нули вы записываете выше в цикле).

 

И еще обратите внимание на такой момент: в логах строка с рядом нулей заканчивается запятой. Возможно, плагин MySQL ее и обрезал, но все-таки, если данный выше ответ не поможет, проверьте, точно ли вся строка с рядом нулей успешно помещается в str.

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


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

@odosenok воо, теперь в столбце появляются, а почему идет от 0?

	format(str, sizeof str, "{00B3FF}Вы нашли %d из 30 подарков", count );
		SendClientMessage(playerid, -1, str);
		format(str, sizeof str, "{00B3FF}Вы получили %d %s", amount, prize );
		SendClientMessage(playerid, -1, str);
		PI[playerid][pPrize][i] = 1;
		SaveGifts(playerid);
		break;

Когда беру 1-й подарок, показывает вы нашли 0 из 30 подарков

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


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