Question

trevison
Активный

суть: аккаунт должен перенесён в другую таблицу и удалиться из нынешней

format(MYSQL_GLOBAL, sizeof(MYSQL_GLOBAL), "INSERT INTO `delacc` SELECT * FROM `accounts` WHERE `nickname` = '%s'", params[0]);
mysql_function_query(MySQLGo, MYSQL_GLOBAL, true"""");
format(MYSQL_GLOBAL, sizeof(MYSQL_GLOBAL), "DELETE FROM `accounts` WHERE `nickname` = '%s'", params[0]);
mysql_query(MySQLGo, MYSQL_GLOBAL);

не срабатывает запрос и в mysql_log ошибка: [ERROR] CMySQLQuery::Execute[] - (error #1136) Column count doesn't match value count at row 1

Share this post


Link to post

8 answers to this question

  • 0
Cawfee
Великий Гуру
1 час назад, trevison сказал:

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

 

С чего бы это? Просто будете рассматривать два атрибута для того, чтобы понять, есть ли валидный зарегистрированный аккаунт с некоторым именем, и извлекать ID найденного аккаунта. И именно по полученному ID в дальнейшем работать с аккаунтом.

 

По меньшей мере странно иметь две одинаковые схемы отношения. Во-первых, это порождает избыточность, во-вторых, увеличивает нагрузку на вас как на разработчика (изменение одной схемы отношения требует изменение другой схемы отношения, а как следствие повышает вероятность возникновения ошибок). В случае же, если в таблице с удаленными аккаунтами вы храните какую-то дополнительную информацию (например, дату и время, когда аккаунт был удален), тогда было бы правильнее делать примерно следующую схему базы данных.

 

изображение_2023-08-24_214440576.png

 

И, соответственно, для того, чтобы удалить аккаунт с ID 10, будет достаточно создать в таблице deleted_accounts новую запись, записав в поле account_id значение 10. А для того, чтобы проверить, есть есть ли валидный аккаунт с некоторым именем, найдите все ID аккаунтов, которые имеют искомое имя, и проверьте, точно ли есть хотя бы один ID, отсутствующий в таблице deleted_accounts.

Share this post


Link to post
  • 0
trevison
Активный

удаление аккаунта с возможностью дальнейшего восстановления

аккаунт уходит в резервную таблицу, а с основной таблицы аккаунт удаляется

появляется возможность восстановить удалённый аккаунт

Share this post


Link to post
  • 0
Cawfee
Великий Гуру

@trevison, опять тот же вопрос: в чем целесообразность? Зачем удалять аккаунт из основной таблицы? Создавайте новое поле в основной таблице, в котором храните признак удаленного аккаунта. 

Share this post


Link to post
  • 0
trevison
Активный

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

в планах, потом сделать так, чтобы при восстановлении аккаунта выбирался новый никнейм, если никнейм уже заняли у удалённого аккаунта

Share this post


Link to post
  • 0
trevison
Активный

хороший вариант реализации, но если так делать, то нужно будет ещё очень много кода переписывать, где проверка идёт на ник ( например: /offjail /offwarn /offmute и всё оффлайн взаимодействие с игроком )

Share this post


Link to post
  • 0
trevison
Активный

хорошо, спасибо вам за совет по реализации

тему можно закрывать

Edited by trevison

Share this post


Link to post
Guest
This topic is now closed to further replies.
Sign in to follow this  
Followers 0
  • Recently Browsing   0 members

    No registered users viewing this page.

  • Similar Content

    • Kalinin
      By Kalinin
      1. Набираю команду для создания CRMP сервера.
      2. Вакансии  которые свободны. Связь через TG @kalinin_sql
      Нам нужны;
      1.Кодеры
      2.Маперы
      3.СММ
      Так-же дружная работа. По поводу зарплаты будем обговаривать все лично в беседе ТГ
       
    • whccompany
      By whccompany
      Rostov Role Play | Rostov RP | CRMP Mobile Project объявляет набор людей в свою команду: Нам требуются:
       
      1. Маппера:
      Сдельная оплата труда от 250 до 3000 рублей/ за 1 работу
       
      2. Специалист по Text Draw:
      Сдельная оплата труда от 400 до 3500 рублей/ за одну работу
       
      3. Pawn разработчик:
      Заработная плата от 10 000 рублей/месяц
       
      4. Программист для создания лаунчера и сайта UCP с автодонатом:
      Заработная плата от 10 000 рублей/месяц
       
      Контакты для связи:
       
      ВКонтакте
       
      Telegram
       
    • Talex
      By Talex
      Игровой сервер Life Game RolePlay
      Скачать файл Игровой сервер Life Game RolePlay
      Добавил Talex Добавлено 28.01.2024 Категория Моды Автор Неизвестно