Вопросы

trevison
Активный

переводил на новую версию mysql и столкнулся с проблемой

при загрузке бизнесов gBusiness[busiID] всегда равняется 0, пробовал исправить разными способами - не получилось

в консоль выводит:

[Загрузка MYSQL]: 75 бизнесов загружено.

и 75 раз: бизнес 0 - 0 загружен

сами пикапы и текст везде расставлены правильно, но именно id - неверно загружает

код:

Спойлер

stock LoadBusiness()
{
    new Cache: result;
    result = mysql_query(connects, "SELECT * FROM `business`");
    gBusinessCount = cache_num_rows();
    if(gBusinessCount >= MAX_BUSINESS_COUNT) print("Кол-во бизнесов в базе превышает предопределнное количество");
    else if (!gBusinessCount) print("Не обнаружено бизнесов в базе");
    else for (new i; i < gBusinessCount; i++)
    {
        cache_get_value_name_int(i, "id", gBusiness[i][busiID]);
        cache_get_value_name(i, "name", gBusiness[i][busiName], strlen(gBusiness[i][busiName]));
        cache_get_value_name_int(i, "type", gBusiness[i][busiType]);
        cache_get_value_name_int(i, "bint", gBusiness[i][busiBint]);
        cache_get_value_name_int(i, "ownerid", gBusiness[i][busiOwnerID]);
        cache_get_value_name_int(i, "sellprice", gBusiness[i][busiSellPrice]);
        cache_get_value_name_int(i, "bank", gBusiness[i][busiBank]);
        cache_get_value_name_int(i, "price", gBusiness[i][busiPrice]);
        cache_get_value_name_int(i, "product", gBusiness[i][busiProduct]);
        cache_get_value_name_int(i, "status", gBusiness[i][busiStatus]);
        cache_get_value_name_int(i, "pricevhod", gBusiness[i][busiEnterPrice]);
        cache_get_value_name_int(i, "burulush", gBusiness[i][busiUrUluch]);
        cache_get_value_name_int(i, "bhealth", gBusiness[i][busiHealHp]);
        cache_get_value_name_int(i, "bkolokol", gBusiness[i][busiKolokol]);
        cache_get_value_name_int(i, "busiGpsSlot", gBusiness[i][busiGpsSlot]);
        cache_get_value_name_float(i, "x", gBusiness[i][busiX]);
        cache_get_value_name_float(i, "y", gBusiness[i][busiY]);
        cache_get_value_name_float(i, "z", gBusiness[i][busiZ]);
        cache_get_value_name_float(i, "r", gBusiness[i][busiR]);
        cache_get_value_name_int(i, "deliving", gBusiness[i][busiDeliving]);
        cache_get_value_name_int(i, "order", gBusiness[i][busiOrder]);
        cache_get_value_name_int(i, "mafia", gBusiness[i][busiMafia]);
        cache_get_value_name_int(i, "rentday", gBusiness[i][busiRentDay]);

        gBusinessArea[i] = CreateDynamicSphere(gBusiness[i][busiX],gBusiness[i][busiY],gBusiness[i][busiZ],2.0);
        CreateDynamicPickup(19132,1,gBusiness[i][busiX],gBusiness[i][busiY],gBusiness[i][busiZ]);
        gBusinessText[i] = CreateDynamic3DTextLabel("_",0xFFFFFFFF,gBusiness[i][busiX],gBusiness[i][busiY],gBusiness[i][busiZ]+1.0,20.0);
        new bizids[100];
        format(bizids,100,"id: %i - %i",i,gBusiness[i][busiID]);
        CreateDynamic3DTextLabel(bizids,0xFFFFFFFF,gBusiness[i][busiX],gBusiness[i][busiY],gBusiness[i][busiZ]+5.0,20.0);
        if(gBusiness[i][busiOwnerID] !=0) gBusiness[i][busiStatus] = 1;
        new icon = 0, bint = gBusiness[i][busiBint];
        if(bint >= 1 && bint <= 4) icon = 49;
        else if((bint >= 5 && bint <= 9) || bint == 23) icon = 45;
        else if(bint >= 17 && bint <= 21) icon = 17;
        else if(bint == 22) icon = 27;
        else if(bint == 14 || bint == 15) icon = 48;
        else if(bint == 24) icon = 51;
        else if(bint == 25) icon = 25;
        else if(bint == 26) icon = 6;
        else if(bint == 16) icon = 47;
        if(icon) gBusinessIcon[i] = CreateDynamicMapIcon(gBusiness[i][busiX], gBusiness[i][busiY], gBusiness[i][busiZ], icon, -1);
        printf("бизнес %d - %i загружен", gBusiness[i][busiID], gBusiness[i][busiID]);
    }
    printf("[Загрузка MYSQL]: %d бизнесов загружено.", gBusinessCount);
    for(new i; i < gBusinessCount; i ++) UpdateBusinessText(i);
    if (cache_is_valid(result)) cache_delete(result);
    return 1;
}

 

 

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

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


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

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

  • 0
𝙡𝙖𝙨𝙩 𝙚𝙢𝙥𝙚𝙧𝙤𝙧.
Создатель WayDev
stock LoadBusiness() {
    new Cache: result = mysql_query(connects, "SELECT * FROM `business`");
    new rows = cache_num_rows();

    if(rows >= MAX_BUSINESS_COUNT) 
        return print("Кол-во бизнесов в базе превышает предопределнное количество");
    if(!rows) 
        return print("Не обнаружено бизнесов в базе");
    
    for(new i; i < rows; i++) {
        cache_get_value_name_int(i, "id", gBusiness[i][busiID]);
        cache_get_value_name(i, "name", gBusiness[i][busiName], strlen(gBusiness[i][busiName]));
        cache_get_value_name_int(i, "type", gBusiness[i][busiType]);
        cache_get_value_name_int(i, "bint", gBusiness[i][busiBint]);
        cache_get_value_name_int(i, "ownerid", gBusiness[i][busiOwnerID]);
        cache_get_value_name_int(i, "sellprice", gBusiness[i][busiSellPrice]);
        cache_get_value_name_int(i, "bank", gBusiness[i][busiBank]);
        cache_get_value_name_int(i, "price", gBusiness[i][busiPrice]);
        cache_get_value_name_int(i, "product", gBusiness[i][busiProduct]);
        cache_get_value_name_int(i, "status", gBusiness[i][busiStatus]);
        cache_get_value_name_int(i, "pricevhod", gBusiness[i][busiEnterPrice]);
        cache_get_value_name_int(i, "burulush", gBusiness[i][busiUrUluch]);
        cache_get_value_name_int(i, "bhealth", gBusiness[i][busiHealHp]);
        cache_get_value_name_int(i, "bkolokol", gBusiness[i][busiKolokol]);
        cache_get_value_name_int(i, "busiGpsSlot", gBusiness[i][busiGpsSlot]);
        cache_get_value_name_float(i, "x", gBusiness[i][busiX]);
        cache_get_value_name_float(i, "y", gBusiness[i][busiY]);
        cache_get_value_name_float(i, "z", gBusiness[i][busiZ]);
        cache_get_value_name_float(i, "r", gBusiness[i][busiR]);
        cache_get_value_name_int(i, "deliving", gBusiness[i][busiDeliving]);
        cache_get_value_name_int(i, "order", gBusiness[i][busiOrder]);
        cache_get_value_name_int(i, "mafia", gBusiness[i][busiMafia]);
        cache_get_value_name_int(i, "rentday", gBusiness[i][busiRentDay]);

        gBusinessArea[i] = CreateDynamicSphere(gBusiness[i][busiX],gBusiness[i][busiY],gBusiness[i][busiZ],2.0);
        CreateDynamicPickup(19132,1,gBusiness[i][busiX],gBusiness[i][busiY],gBusiness[i][busiZ]);
        gBusinessText[i] = CreateDynamic3DTextLabel("_",0xFFFFFFFF,gBusiness[i][busiX],gBusiness[i][busiY],gBusiness[i][busiZ]+1.0,20.0);
        
        new bizids[100];
        format(bizids,100,"id: %i - %i",i,gBusiness[i][busiID]);
        CreateDynamic3DTextLabel(bizids,0xFFFFFFFF,gBusiness[i][busiX],gBusiness[i][busiY],gBusiness[i][busiZ]+5.0,20.0);
        
        if(gBusiness[i][busiOwnerID] != 0
            gBusiness[i][busiStatus] = 1;

        new icon = 0
            bint = gBusiness[i][busiBint];

        if(bint >= 1 && bint <= 4) icon = 49;
        else if((bint >= 5 && bint <= 9) || bint == 23) icon = 45;
        else if(bint >= 17 && bint <= 21) icon = 17;
        else if(bint == 22) icon = 27;
        else if(bint == 14 || bint == 15) icon = 48;
        else if(bint == 24) icon = 51;
        else if(bint == 25) icon = 25;
        else if(bint == 26) icon = 6;
        else if(bint == 16) icon = 47;
        
        if(icon) 
            gBusinessIcon[i] = CreateDynamicMapIcon(gBusiness[i][busiX], gBusiness[i][busiY], gBusiness[i][busiZ], icon, -1);
        
        printf("бизнес %d - %i загружен", gBusiness[i][busiID], gBusiness[i][busiID]);
    }
    printf("[Загрузка MYSQL]: %d бизнесов загружено.", rows);
    for(new i; i < rows; i ++) 
        UpdateBusinessText(i);

    if(cache_is_valid(result)) 
        cache_delete(result);
        
    return 1;
}

 

Отредактировано пользователем 𝙡𝙖𝙨𝙩 𝙚𝙢𝙥𝙚𝙧𝙤𝙧.

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


Ссылка на сообщение
  • 0
trevison
Активный

Сделал mysql_log(all); 

и в логах айди определяет вроде верно, но в gBusiness[busiID] записывает 0 

ошибок/варнингов никаких нет

Спойлер

XNffw.png

 

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

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


Ссылка на сообщение
  • 0
trevison
Активный

пробовал поставить R39-3, пробовал экспериментировать с подключением к бд и менял кодировки, пробовал несколько раз переписать загрузку (пример брал с разных модов на mysql r41-4) и ничего из этого не помогает, даже комментировал предыдущие загрузки домов и прочее - эффекта никакого, даже через таймер попробовал

и пробовал менять столбец "id" на "bID" и всяко разно, ничего из этого не помогает и у самой таблицы менял кодировку

и всегда cache_get_value_name_int(i, "id", gBusiness[busiID]); - не записывает именно "id" в gBusiness[busiID], а остальное всё загружает

я даже не знаю что ещё можно попробовать сделать

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

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


Ссылка на сообщение
  • 0
trevison
Активный

немного разобрался, если cache_get_value_name_int(i, "id", gBusiness[busiID]); 

поменять местами с cache_get_value_name(i, "name", gBusiness[busiName], strlen(gBusiness[busiName]));

то проблема с айди уходит и появляется проблема уже с названием бизнеса, т.е. не записывается именно первый cache_get_value_name ( или cache_get_value_name_int )

из-за чего данная проблема могла возникнуть и как её исправить?

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


Ссылка на сообщение
Гость
Эта тема закрыта для публикации ответов.
  • Последние посетители   0 пользователей онлайн

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

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

    • Дебилойд
      От Дебилойд
      Здравствуйте!
      Мы ищем талантливого 3D-моделлера в команду нашего CRMP-проекта!
      Что нужно будет делать:
      Моделировать и адаптировать автомобили.
      Создавать и настраивать скины (модели персонажей).
      Большим плюсом будет:
      Умение создавать качественные и оптимизированные интерьеры.
      Если вы хотите стать частью нашей команды и развивать проект вместе с нами, пишите в ЛС. Ждем ваши портфолио!
    • LORDIKUS
      От LORDIKUS
      Уважаемые участники форума - всех приветствую, кто перешел в беседу моей темы обсуждения. В настоящее время у меня зарождается огромное желание и мысль создать собственный CR:MP проект, но столкнулся с единственной проблемой - с отсутствием команды людей, у которых будет искреннее желание ежедневно вкладывать свой труд на разработку проекта. Особого опыта в скриптинге, маппинге, дизайне или в моделировании у меня не имеется, поэтому такой критерий как опыт в определенной сфере для желающих вступить в команду я не рассматриваю. Так как проект не открыт и находится на начальной стадии создания, мое сотрудничество выстраивается на некоммерческой основе (без выплаты за проделанную работу и труд), однако я не собираюсь отрицать высокую ценность вложенного командой труд — труд, особенно на первой стадии разработки я рассматриваю превыше всего. После открытия проекта в зависимости от коммерции и чистой прибыли каждый участник будет получать настоящую выплату, однако это также может убить еще значительное время. Мне нужна команда, которая проявит искренний интерес в создании общего между командой CR:MP проекта, пожертвует свое время, а также вложит собственный труд благодаря заработанным навыкам. Если вас заинтересовала данная тема обсуждения, пожалуйста, свяжитесь со мной по любым возможным и удобным для вас контактам связи ниже. Спасибо всем, кто зашел в мою беседу!

      🔗 Спец. Связь:
      — DISCORD: https://discord.com/users/1452715348196589691 (перейти по ссылке и добавить в друзья) ИЛИ _shin833_ (ввести никнейм и отправить запрос дружбы)
      — VK: https://vk.com/shin833
      — TG: https://t.me/s_hin833
    • Korochansky
      От Korochansky
      Настало время объявить о скором выпуске первого релиза среды разработки под названием Spawn.

      В настоящее время программа находится на заключительных этапах доработки кода и локализации интерфейса.
      Таким образом, в течение следующей недели будет выпущена быстрая и современная среда разработки, обладающая следующими возможностями (о которых я расскажу сейчас, а о других — позже):
       
      Полнофункциональный локальный Git: 
      Индексирование, фиксации, индикаторы состояния и мягкий/жесткий сброс до любой точки сохранения одним щелчком мыши. Разрабатывайте свой игровой сервер, не боясь его сломать.
      Новички могут рассматривать это как историю кодовой базы вашего сервера (что и есть на самом деле).
       
      Чистый UTF-8 (без BOM): 
      Полный отказ от устаревшей кодировки Windows-1251 (CP1251) для абсолютной стабильности и идеальной совместимости с Git.
      Реализация поддержки CP1251 привела бы к нестабильному поведению программы и ухудшила бы пользовательский опыт.
       
      История изменений строк: Редактор выделяет измененные строки в реальном времени в полях рядом с номерами строк. Это позволяет мгновенно видеть границы изменений, внесенных с момента открытия файла.
       
      Сопоставление и выделение фигурных скобок: мгновенное выделение открывающих и закрывающих фигурных скобок для быстрой навигации по структуре кода и защиты от ошибок компиляции.
       
      Интеграция с SAMPCTL: готовая к использованию автоматизация процессов. Сборка, запуск сервера и менеджер зависимостей (управление библиотеками и плагинами) работают напрямую из интерфейса редактора.
       
      И многое другое...
       
      И самое главное: проект будет с открытым исходным кодом под лицензией GPLv3!
      Следите за новостями о выпуске в репозитории: https://github.com/daniilkorochansky/spawn
    • KodBi
      От KodBi
      шапка
      по одиночке работают
      нужны оба