Вопросы

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

#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 пользователей онлайн

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

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

    • Talex
      От Talex
      Всем привет, сливаю первый мод!
      Информация о моде:

      — Основа Gamenix.
      — Мод переведен на Mysql R39, теперь ни каких слётов нет, мод работает стабильно с онлайном 160+.
      — Новый автосалон на TextDraw.
      — Система 3-х автомобилей (1 можно купить по дефолту, 2 и 3 за донат).
      — Автомобили у игроков теперь не пропадают (Id'ы авто сбивались, с номерами теперь тоже всё в порядке).
      — Оформление сервера полностью переработано, теперь оно более красивое.
      — Защита от копирования карты.
      — в меню сервера добавлен пункт визуальных настроек.
      — Номера на транспорт теперь можно приобрести в /donate.
      — Сделан новый красивый спидометр.
      — При получении номера, добавлен выбор региона.
      — Сделана система радаров и промокодов, создание прямо из игры.
      — Новый интерьер казино.
      — Магазин скинов теперь на TextDraw.
      — Автошкола полностью функционирует.
      — Добавлена информация после коннекта о последнем входе в собственный аккаунт.
      — Приватная защита от всех видов DDoS атак и DoS атак.                                                                                                                                    
      — пароль от АП (/alog) теперь у каждого администратора индивидуальный.
      — Изменено оформление самого мода
      Это не все изменения мода, их ещё очень много. все не упомнишь. 
      Автор мода: Неизвестен
      CUNBERS RP 8.4.3.rar