Вопросы

Приветствую вас мои дорогие, давненько меня тут не было, решил опять заняться рукоделием, так вот, с чем я к вам пожаловал, у меня не создается строка в базе, вот собственно весь код, ну а мой мозг собственно все: 

Спойлер

CMD:addhouse(playerid, params[])
{
    new HousePrice,id = HouseHow;
	if(pInfo[playerid][pAdmin] < 5) return SCM(playerid, -1, "{FF8C00}[x]{FFFFFF}Доступно исключительно для администрации");
	if(sscanf(params, "ii", params[0], HousePrice)) return SCM(playerid, -1, "{FF8C00}[x]{FFFFFF}/addhouse [Класс] [Цена]");
	new Float:x;
	new Float:y;
	new Float:z;
	GetPlayerPos(playerid, x, y, z);
	hData[id][hPosX] = x;
	hData[id][hPosY] = y;
	hData[id][hPosZ] = z;
 	hData[id][VirtualWorld] = GetPlayerVirtualWorld(playerid);
 	format(hData[id][hOwner],24,"Государство");
    SendClientMessage(playerid,-1,"{FF8C00}[x]{FFFFFF}Дом был успешно добавлен!");
    hData[id][HouseEnter]  = CreateDynamicCP(x,y,z,1.5,GetPlayerVirtualWorld(playerid));
    hData[id][HouseExit] = CreateDynamicCP(443.9237,509.4609,1001.4195,1.5,GetPlayerVirtualWorld(playerid));//Телепорт в интерьер №1 | Потом переделать
	new labelstring[100];
    format(labelstring,sizeof(labelstring),"Владелец: Государство \nЦена: %i",HousePrice);//форматируем строку с 3D текстом
    hData[id][HouseLabel] = Create3DTextLabel(labelstring,0xFF0000FF,x,y,z,25.0,GetPlayerVirtualWorld(playerid));
    HouseHow++;//увеличиваем кол-во домов.
    
    new query_string[256];
    format(query_string, sizeof(query_string), "INSERT INTO `houses` (`ID`, `Owner`, `Cena`, `PosX`, `PosY`, `PosZ`, `Status`, `Enter`, `Exit`, `Virtual`) VALUES ('%s', '%s', '%d', '%d' '%d', '%d', '%s', '%d', '%d', '%d')", HouseHow, hData[id][hOwner], hData[id][hCena], hData[id][hPosX], hData[id][hPosY], hData[id][hPosZ], hData[id][hStatus], hData[id][HouseEnter], hData[id][HouseExit], hData[id][VirtualWorld]);
    mysql_function_query(mysql_connect_ID, query_string, false, "", "");
	return true;
}

 

Спасибо мои дорогие за помощь нищим 

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

Заметка от Shakoladka , создано

Код больше 10-ти строк нужно брать под спойлер, не первый раз предупреждаем, следующий раз будет выдано предупреждение

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


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

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

  • 0

posX/ и т.п %f, так как это флоат.
Логи mysql в студию

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


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

@keyl1337 логи: 

[22:45:20] [ERROR] CMySQLQuery::Execute[] - (error #1064) You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '' Ђ`@' at line 1

Исправил с координатами 

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

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


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

mysql r41?
попробуй %f добавить на координаты и потесть, и логи чекни будет ошибка или нет

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

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


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

@keyl1337 r39-5

 

UPD: Ошибки нету

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

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


Ссылка на сообщение
  • 0
CMD:addhouse(playerid, params[])
{
    new HousePrice,id = HouseHow;
	if(pInfo[playerid][pAdmin] < 5) return SCM(playerid, -1, "{FF8C00}[x]{FFFFFF}Доступно исключительно для администрации");
	if(sscanf(params, "ii", params[0], HousePrice)) return SCM(playerid, -1, "{FF8C00}[x]{FFFFFF}/addhouse [Класс] [Цена]");
	new Float:x;
	new Float:y;
	new Float:z;
	GetPlayerPos(playerid, x, y, z);
	hData[id][hPosX] = x;
	hData[id][hPosY] = y;
	hData[id][hPosZ] = z;
 	hData[id][VirtualWorld] = GetPlayerVirtualWorld(playerid);
 	format(hData[id][hOwner],24,"Государство");
    SendClientMessage(playerid,-1,"{FF8C00}[x]{FFFFFF}Дом был успешно добавлен!");
    hData[id][HouseEnter]  = CreateDynamicCP(x,y,z,1.5,GetPlayerVirtualWorld(playerid));
    hData[id][HouseExit] = CreateDynamicCP(443.9237,509.4609,1001.4195,1.5,GetPlayerVirtualWorld(playerid));//Телепорт в интерьер №1 | Потом переделать
	new labelstring[100];
    format(labelstring,sizeof(labelstring),"Владелец: Государство \nЦена: %i",HousePrice);//форматируем строку с 3D текстом
    hData[id][HouseLabel] = Create3DTextLabel(labelstring,0xFF0000FF,x,y,z,25.0,GetPlayerVirtualWorld(playerid));
    HouseHow++;//увеличиваем кол-во домов.
    
    new query_string[256];
    format(query_string, sizeof(query_string), "INSERT INTO `houses` (`ID`, `Owner`, `Cena`, `PosX`, `PosY`, `PosZ`, `Status`, `Enter`, `Exit`, `Virtual`) VALUES ('%d', '%s', '%d', '%f' '%f', '%f', '%s', '%f', '%f', '%d')", HouseHow, hData[id][hOwner], hData[id][hCena], hData[id][hPosX], hData[id][hPosY], hData[id][hPosZ], hData[id][hStatus], hData[id][HouseEnter], hData[id][HouseExit], hData[id][VirtualWorld]);
    mysql_function_query(mysql_connect_ID, query_string, false, "", "");
	return true;
}

Позиции всегда обозначаются в "%f", я тебе заменил. ID, это же число, а не буквы или слово, значит обозначается "%d", а не "%s", как это было у тебя. Проверь в базе данных.

Название тип

ID integer

Owner warchar(25) - 25 - длина

Cena integer

PosX float

PosY float

PosZ float

Status varchar(длины не знаю)

Enter float

Exit float

Virtual integer

 

Я не уверен, но думаю, что Enter и Exit это координаты входа и выхода, если это так, то они должны обозначаться "%f" и в таблице иметь тип "float", если нет, то "%d" и в таблице "integer"

 

 

Заметка от Shakoladka , создано

Код больше 10-ти строк нужно брать под спойлер

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


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

@SCRIPTMAN увы, все так же не добавляется 

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


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

@Remmi_Jefferson mysql логи предоставь

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


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

@SCRIPTMAN 

[21:43:44] [ERROR] CMySQLQuery::Execute[] - (error #1136) Column count doesn't match value count at row 1

 

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


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

@Remmi_Jefferson, если этот вариант не поможет, то показывайте объявление переменных hCena и hStatus.

Спойлер

CMD:addhouse(playerid, params[])
{
	new HousePrice,id = HouseHow;
	if(pInfo[playerid][pAdmin] < 5) return SCM(playerid, -1, "{FF8C00}[x]{FFFFFF}Доступно исключительно для администрации");
	
	if(sscanf(params, "ii", params[0], HousePrice)) return SCM(playerid, -1, "{FF8C00}[x]{FFFFFF}/addhouse [Класс] [Цена]");
	new Float:x;
	new Float:y;
	new Float:z;
	GetPlayerPos(playerid, x, y, z);
	hData[id][hPosX] = x;
	hData[id][hPosY] = y;
	hData[id][hPosZ] = z;
	hData[id][VirtualWorld] = GetPlayerVirtualWorld(playerid);
	format(hData[id][hOwner],24,"Государство");
	SendClientMessage(playerid,-1,"{FF8C00}[x]{FFFFFF}Дом был успешно добавлен!");
	hData[id][HouseEnter]  = CreateDynamicCP(x,y,z,1.5,GetPlayerVirtualWorld(playerid));
	hData[id][HouseExit] = CreateDynamicCP(443.9237,509.4609,1001.4195,1.5,GetPlayerVirtualWorld(playerid));//Телепорт в интерьер №1 | Потом переделать
	new labelstring[100];
	format(labelstring,sizeof(labelstring),"Владелец: Государство \nЦена: %i",HousePrice);//форматируем строку с 3D текстом
	hData[id][HouseLabel] = Create3DTextLabel(labelstring,0xFF0000FF,x,y,z,25.0,GetPlayerVirtualWorld(playerid));
	HouseHow++;//увеличиваем кол-во домов.

	new query_string[256];
	format(query_string, sizeof(query_string), "INSERT INTO `houses` (`ID`, `Owner`, `Cena`, `PosX`, `PosY`, `PosZ`, `Status`, `Enter`, `Exit`, `Virtual`) VALUES ('%d', '%s', '%d', '%f' '%f', '%f', '%d', '%d', '%d', '%d')", HouseHow, hData[id][hOwner], hData[id][hCena], hData[id][hPosX], hData[id][hPosY], hData[id][hPosZ], hData[id][hStatus], hData[id][HouseEnter], hData[id][HouseExit], hData[id][VirtualWorld]);
	mysql_function_query(mysql_connect_ID, query_string, false, "", "");
	return true;
}

 

 

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


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

@odosenok 

#define MAX_HOUSES 100
enum house_data
{
	hID,
	hOwner,
	hCena,
	hPosX,
	hPosY,
	hPosZ,
	hStatus,
	HouseEnter,
	HouseExit,
	VirtualWorld,
};
new hData[MAX_HOUSES][house_data];
new Text3D:HouseLabel;
new HouseHow;//Сколько домов создали
new PlayerInHouseID[MAX_PLAYERS];

Сразу все переменные относящиеся к системе покажу

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


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

@Remmi_Jefferson, а в логах то же самое пишет?

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


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

@odosenok в mysql - да: 

[22:48:55] [ERROR] CMySQLQuery::Execute[] - (error #1136) Column count doesn't match value count at row 1

 

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


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

@Remmi_Jefferson Количество столбцов не совпадает количество значений в строке 1 by Yandex.Translate

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


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

@Remmi_Jefferson, а у поля ID в структуре таблицы стоит "AUTO_INCREMENT"?

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


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

@SCRIPTMAN Увы, пересчитал, все совпадает

@odosenok Нет, но в атрибутах у меня его в принципе нету 

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


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