Вопросы

Всем доброго времени суток. Расширил в моде количество личных автомобилей для игрока с 1 до 3-х и столкнулся с проблемой, что номера после перезагрузки сервера слетают. Вот некоторый код.

 

Спойлер

enum e_PLAYER_INFO
{

//
    pRegVehicle[3],
    pNumberVehicle_1[20],
    pNumberVehicle_2[20],
    pNumberVehicle_3[20],
// ---

 

Спойлер

case dVehNumber:
        {
            if(!response) return ShowPlayerDialog(playerid, dMenuPolice, DIALOG_STYLE_LIST, "{FFCC00}Что Вас интересует?", "1. Оформление лицензии на оружие\n2. Оплата штрафов\n3. Получение гос.номера на Т/С\n4. Сдаться с повинной", "Выбрать", "Отмена");
            if(pTemp[playerid][pCarPlayerID] == INVALID_VEHICLE_ID) return SendClientMessage(playerid, COLOR_GREY, "[Ошибка] У вас нету машины!");
            if(pInfo[playerid][pRegVehicle] == 1) return SendClientMessage(playerid, COLOR_GREY, "[Ошибка] У вас уже имеется номерной знак на этом авто!");
             new number[64], string[200];
              /*for(new i; i != 15; i++)
            {
                if(!i) number = random('Z' - 'A') + 'A';
                if(i >= 1 && i <= 3) number = random('9' - '0') + '0';
                if(i > 3) number = random('Z' - 'A') + 'A';
                if(i >= 5) number = + ' | ';
                if(i > 7) number
               }*/
               format(number, 64, "%s%d%d%d%s%s", VehNumber(), random(9), random(9), random(9), VehNumber(), VehNumber(), random(9),random(9));
               strmid(pInfo[playerid][pNumberVehicle], number, 0, strlen(number), 64);
               pInfo[playerid][pRegVehicle] = 1;
            SetVehicleNumberPlate(pTemp[playerid][pCarPlayerID], pInfo[playerid][pNumberVehicle]);
            format(string, sizeof(string), "{FFFFFF}Место регистрации: {0000FF}ГИБДД г.Южный{FFFFFF}\nГос.номер вашего Т/С: {63BD4E}%s", number);
            ShowPlayerDialog(playerid, dNull, DIALOG_STYLE_MSGBOX, "{FFCC00}Информация", string, "Закрыть", "");
            format(string, sizeof(string), "%s[%i] зарегистрировал гос.номер на своё Т/С [%s]", GetName(playerid), playerid, number);
            foreach(new i : Player)
            {
                if(!gPlayerLogged) continue;
                if(IsACop(i)) SendClientMessage(i, 0x3399FFFF, string);
            }
            ///
               //Delete3DTextLabel(VehicleLabel[pTemp[playerid][pCarPlayerID]]);
              format(string,sizeof(string),"%s",pInfo[playerid][pNumberVehicle]);
            if(VehicleLabel[pTemp[playerid][pCarPlayerID]] != Text3D:INVALID_3DTEXT_ID)
            {
                UpdateDynamic3DTextLabelText(VehicleLabel[pTemp[playerid][pCarPlayerID]], 0xFFFFFFFF, string);
            }
            ///
            mysql_query_string[0] = EOS;
            format(mysql_query_string, 200, "UPDATE "T_ACCOUNTS" SET veh_reg = %i, veh_number = '%s' WHERE id = %i", pInfo[playerid][pRegVehicle], pInfo[playerid][pNumberVehicle], pInfo[playerid][pID]);
            mysql_tquery(dbHandle, mysql_query_string, "", "");
        }

 

 

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


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

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

  • 0

@glvde. У меня есть такое:

  `veh_number_1` varchar(20) CHARACTER SET utf8 NOT NULL DEFAULT 'None',
  `veh_number_2` varchar(20) CHARACTER SET utf8 NOT NULL DEFAULT 'None',
  `veh_number_3` varchar(20) CHARACTER SET utf8 NOT NULL DEFAULT 'None',
  `veh_reg_1` int(1) NOT NULL DEFAULT '0',
  `veh_reg_2` int(1) NOT NULL DEFAULT '0',
  `veh_reg_3` int(1) NOT NULL DEFAULT '0',

Это столбцы в БД

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


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

Значит, логично, нужно их сохранить при получении?

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


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

@20th century 

Я скинул код получения номеров. Там разве нету их сохранения?

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


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

@HAPKOMAH Ну логично, если же после рестарта номера слетают, значит нужно сделать загрузку для них, или же доработать(если она есть).

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

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


Ссылка на сообщение
  • 0
В 03.10.2020 в 23:35, HAPKOMAH сказал:

format(mysql_query_string, 200, "UPDATE "T_ACCOUNTS" SET veh_reg = %i, veh_number = '%s' WHERE id = %i", pInfo[playerid][pRegVehicle], pInfo[playerid][pNumberVehicle], pInfo[playerid][pID]);
            mysql_tquery(dbHandle, mysql_query_string, "", "");

@Nekit_Krut18  @20th century  прежде чем писать что-то бездумное, при желании помочь, изучите всю предоставленную информацию. 

Конкретно по теме: в базе номера есть? Если есть, значит проблемы с загрузкой и нужен код загрузки

 

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

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


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

@keyl1337 Да, правда они туда по моему не сохраняются. Получил номера - обновил БД, а в столбце ничего не изменилось. 

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


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

@HAPKOMAH Ну тогда, можно получить логи mysql ?

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


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

@Nekit_Krut18 

Нашёл там вот такую строчку. Помоему она единственная связанная с номерами была.

[00:40:49 10/04/20] [ERROR] CMySQLQuery::Execute[] - (error #1054) Unknown column 'veh_reg' in 'field list' (Query: "UPDATE accounts SET veh_reg = 1, veh_number = 'H124ME' WHERE id = 139")

 

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


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

@HAPKOMAH  Неизвестный столбец - veh_reg. Смотрите в таблице accounts, столбец veh_reg, возможно его нет, если его нету то добавьте.

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

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


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

@Nekit_Krut18  Так-с. У меня вроде три столбца: veh_reg1, veh_reg2, veh_reg3. Машины все таки три. Я так понял, что в сохранении значит проблема, раз там просто veh_reg

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


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

@HAPKOMAH, создайте столбец veh_reg, со стандартным значением 0.

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


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