Вопросы

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

#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 ко всем записям в табличке. 

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

Спойлер

stock ResetBizz()
{
    mysql_function_query(connects, "UPDATE business SET `owner_id` = '0', `products` = '0', `prod_price` = '0', `lock` = '0', `eviction` = '0'"false"","");
    LoadBizz();
}

 

 

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


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

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

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


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

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

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

    • Доналдо Фарекелка
      От Доналдо Фарекелка


      Скачать файл Arizona RolePlay || Ser
      Приветствую, этот мод я нашёл на просторах интернета. 
      Скачал мод у автора:  Developer Stravinskiy
      Доработал мод: Donaldo_Farekelka
       
      Предупреждаю! Мод сырой, багов стало меньше, но они есть.
      Мод: Баня, Подвал, В некоторых местах маппинг, система коронавируса, 8 лвл админок
       
      Информация:
      1) Dc_Cmd
      2) Mysql, mode, language - Всё настраивается теперь в pawno ( UPDATE: 1.1.0 )
      3) Административные права в данный момент можно выдать только через MYSQL ( BD ).
       
      То что я сделал ( Всё что я делаю сейчас, смотрите в изменениях ):
       
      Добавил Доналдо Фарекелка Добавлено 13.04.2023 Категория Моды Автор shenol (vk.com/donaldo_farekelka)  
    • Доналдо Фарекелка
      От Доналдо Фарекелка
      Приветствую, этот мод я нашёл на просторах интернета. 
      Скачал мод у автора:  Developer Stravinskiy
      Доработал мод: Donaldo_Farekelka
       
      Предупреждаю! Мод сырой, багов стало меньше, но они есть.
      Мод: Баня, Подвал, В некоторых местах маппинг, система коронавируса, 8 лвл админок
       
      Информация:
      1) Dc_Cmd
      2) Mysql, mode, language - Всё настраивается теперь в pawno ( UPDATE: 1.1.0 )
      3) Административные права в данный момент можно выдать только через MYSQL ( BD ).
       
      То что я сделал ( Всё что я делаю сейчас, смотрите в изменениях ):
       
    • Redmondd
      От Redmondd
      Когда в игре ввожу команду /gps, нажимаю на Важные места то окно просто закрывается, так же с Государственными организациями и Вокзалами