Вопросы

Хочу сделать вайп бизнесов,но выдет ошибку

#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 '%d' at line 1

Ввожу в SQL

UPDATE business SET `owner_id` = '0', `products` = '0', `prod_price` = '0', `lock` = '0', `eviction` = '0' WHERE `id` = %d

 

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


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

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

  • 0

@Azix 
 

UPDATE business SET `owner_id` = '0', `products` = '0', `prod_price` = '0', `lock` = '0', `eviction` = '0'

 

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


Ссылка на сообщение
  • 0
UPDATE business SET `owner_id` = '0', `products` = '0', `prod_price` = '0', `lock` = '0', `eviction` = '0' WHERE `owner_id` != '0'

 

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


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

@glvde. А если нужно обнулить всё данные кроме owner_id, а owner_id будет равняться 0 ? Вариант хороший, но не всегда подойдёт.

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

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


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

@Azix Вот код:

 

new mysql_text[144];

format(mysql_text, sizeof(mysql_text), "UPDATE business SET `owner_id` = '0', `products` = '0', `prod_price` = '0', `lock` = '0', `eviction` = '0' WHERE `id` = '%d' ", integer);

// команды выполнения запроса, только с уже отформатированный строкой mysql_text

 

P. S. Сори за код не под тегом, пишу с телефона. 

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

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


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

@Sleash`en Если нужно будет обнулить все дома, то ваш код не сработает.

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


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

@LoX_1337 Ну - во-первых бизнесы, а во-вторых, почему?

Вот по-быстрому набросил сток  для обнуления бизов

stock ResetBizz()
{
    new mysql_text[1024], ii;
    for(new i; i < sizeof(BizzInfo); i++)
    {
        format(mysql_text, sizeof(mysql_text), "%sUPDATE business SET `owner_id` = '0', `products` = '0', `prod_price` = '0', `lock` = '0', `eviction` = '0' WHERE `id` = '%d';\n",mysql_text, i);
        // Так же можно юзать strcat();
        ii+;
    }
    mysql_function_query(connects, mysql_text, false"","");
    printf("Успешно обнулено %d бизнесов", ii);
    LoadBizz();
    return true;
}

Да, чуть подредачил добавив переменную, %s и \n в формат, но это было сделано для использования в цикле. 

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

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


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

@Sleash`en Глупое решение. Посмотрите мой первый комментарий, где я оставил подходящие решение.

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


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

@LoX_1337 Кому как лучше - тот так и использует.

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

2.17. Запрещено флудить, оффтопить, заниматься флеймом. 

Устное предупреждение.

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


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

@Sleash`en Почему большинство крупных проектов всегда пытаются улучшать мод ? Почему не сделать как вы сказали ? У вас очень глупые и необдуманные мысли.

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

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

2.17. Запрещено флудить, оффтопить, заниматься флеймом. 

Устное предупреждение.

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

Давайте больше делать упор на критику решений (кода/архитектуры), без привязки/перехода к личностям.

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


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

@Sleash`en в строке для одного бизнеса 124 ячейки, всего строка на 1024. Следовательно, если в моде больше 8 бизнесов, этот код не будет работать. 

Если необходимо обновить все записи в таблице, не нужно указывать WHERE. В этом случае база применит SET ко всем записям в табличке. 

Поэтому, можно упростить следующим образом: 

  открыть спойлер

 

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


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

@DEST Спасибо за объяснения, не очень много работал с MySQL.

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


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

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

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

    • RASTAMAN
      От RASTAMAN
      Для того чтобы дать пароль нужно быть администратором 10 lvl после того пишем в чат /passadm
       
      Система казино Система домов Система авто И многие другие системы!

      Особых багов не найдено.

      В моде присутствует 25 фракции.
      Есть Textdraw на спавне!
    • RASTAMAN
      От RASTAMAN
      Plantinum RolePlay
      Скачать файл Для того чтобы дать пароль нужно быть администратором 10 lvl после того пишем в чат /passadm
       
      Система казино Система домов Система авто И многие другие системы!

      Особых багов не найдено.

      В моде присутствует 25 фракции.
      Есть Textdraw на спавне!
      Добавил RASTAMAN Добавлено 10.10.2017 Категория Моды Автор неизвестен  
    • Michov Andr
      От Michov Andr
      Re:samp RP — проект в разработке
      Re:samp RP — это SA-MP в стиле RP-проект, который в данный момент находится в активной разработке. Мы создаём сервер с бонусной системой, где механики будут, и игроки смогут развивать свои персонажи, зарабатывать деньги и взаимодействовать с окружающим миром. Однако, главное — это ролевой процесс. Вы сами выбираете, хотите ли вы заниматься бизнесом и фармом или погружаться в глубокую ролевую игру. Всё зависит от того, какой путь вы хотите пройти.
      Мы стремимся к тому, чтобы на сервере не было скучного фарма и бесконечных рутинных задач. Всё будет сбалансировано так, чтобы каждый игрок мог выбрать свой стиль игры и наслаждаться процессом, будь то отыгрыш роли, развитие персонажа или участие в экономике.
      Что касается доната — на сервере будет доступна возможность покупки привилегий, включая покупку админки. Мы не планируем делать донат обязательным для прогресса, и он не будет влиять на геймплей, но те, кто хотят ускорить процесс или получить дополнительные возможности, смогут воспользоваться такими предложениями. Всё сделано так, чтобы не нарушать баланс и не превращать сервер в платный путь к успеху.
      Re:samp RP — это сервер, где каждый игрок может найти для себя интересное занятие и, главное, где всегда будет место для качественной ролевой игры. Мы не навязываем никаких обязательных механик, и все решения остаются за вами. Стартовый бонус, донат, админки — это всё дополнительные возможности, но не основа игры. 
      Discrod:https://discord.gg/ernRMjyEJy
       
             
      на логотип не смотрим да признаюсь взял с самп рп() но уж больно он норм)
    • djxxx
      От djxxx
      приветствую всех.
       
      Задался таким вопросом при добавлении одной системы на DIALOG_STYLE_TABLIST_HEADERS.
       
      Суть проблемы в том, что диалог не выравнивается под нужные показатели, а просто как будто находиться по середине, в диалоге используется \t, но они особо не помогают в решении, также не ровно.
       
      а если попытаться выравнивать большим количеством \t, оно компилируется но в игре происходят вылеты
       
      Код такой:
      DialogAdmShop ( playerid, DIALOG_EPOINTSHOP, DIALOG_STYLE_TABLIST_HEADERS, fmt_str, ""BR"номер\t"BR"наименование\t"BR"доступное действие\n"\ "{EB4C42}#1\t{FFFFFF}Виртуальная валюта\t{888888}нажмите для взаимодействия\n"\ "{EB4C42}#2\t{FFFFFF}Донат валюта\t{888888}нажмите для взаимодействия\n"\ "{EB4C42}#3\t{FFFFFF}Вип статусы\t{888888}нажмите для взаимодействия\n"\ "{EB4C42}#4\t{FFFFFF}Кейсы\t{888888}нажмите для взаимодействия\n"\ "{EB4C42}#5\t{FFFFFF}Уникальные аксессуары\t{888888}нажмите для взаимодействия", "Выбрать", "Закрыть" ); }  
      сток dialogadmshop:
      stock DialogAdmShop(playerid, dialogid, style, title[], text[], button[], button2[]) {   if(style == 5)   {      ShowPlayerDialog(playerid, 0, DIALOG_STYLE_LIST, "...", "...", "...", "");    }   ShowPlayerDialog(playerid, dialogid, style, title, text, button, button2);   return 1; }