Добро пожаловать на Pro Pawn - Портал о PAWN-скриптинге.
Показано с 1 по 8 из 8
  1. #1
    Аватар для SteveStage
    Пользователь

    Статус
    Оффлайн
    Регистрация
    05.10.2019
    Адрес
    Планета Земля
    Сообщений
    318
    Репутация:
    7 ±

    (error #1467) Failed to read auto-increment value from storage engine

    Вот команда выдачи лидерки человеку:

    1. CMD:makeleader(playerid, params[])
    2. {
    3. if(login_check{playerid} == false)
    4. return true;
    5. if(player[playerid][p_admin] == 0)
    6. return SCM(playerid, COLOR_RED, !"Вы не администратор!");
    7. if(player[playerid][p_admin] <= 7)
    8. return SCM(playerid, COLOR_RED, !"Ваш админ-уровень не позволяет вам назначать игроков лидерами организаций!");
    9. new
    10. targetid,
    11. type;
    12. if(sscanf(params, "ud", targetid, type))
    13. return SCM(playerid, COLOR_RED, !"Образец назначения лидера в организацию: /makeleader [id] [type]");
    14. if(!IsPlayerConnected(targetid))
    15. return SCM(playerid, COLOR_RED, !"Игрок с введенным вами ID не в сети!");
    16. if(login_check{targetid} == false)
    17. return SCM(playerid, COLOR_RED, !"Игрок в введенным вами ID не авторизован!");
    18. if(type > MAX_FRACTIONS || type == INVALID_FRACTION_TYPE || type < 0)
    19. return SCM(playerid, COLOR_RED, !"Указан некорректный тип организации!");
    20. new
    21. string[144+1];
    22. format(string, sizeof(string), "Администратор %s назначил игрока %s лидером %s", GetName(playerid), GetName(targetid), frac_list[type]);
    23. SCMTA(COLOR_RED, string);
    24. mysql_format(connect_mysql, string, sizeof(string),
    25. "INSERT INTO `fractions` (`rank`, `type`, `name`) VALUES ('10', '%d', '%s')", type, GetName(targetid));
    26. mysql_function_query(connect_mysql, string, false, "", "");
    27. mysql_format(connect_mysql, string, sizeof(string), "SELECT * FROM `fractions` WHERE `name` = '%s' LIMIT 1", GetName(targetid));
    28. mysql_function_query(connect_mysql, string, true, "@_LoadFrac", "d", targetid);
    29. return true;
    30. }


    1. @_LoadFrac(playerid);
    2. @_LoadFrac(playerid)
    3. {
    4. new
    5. rows,
    6. fields;
    7. cache_get_data(rows, fields);
    8. if(rows)
    9. {
    10. cache_get_field_content(0, "name", frac[playerid][f_name], MAX_PLAYER_NAME+1);
    11. frac[playerid][f_id] = cache_get_field_content_int(0, "id");
    12. frac[playerid][f_rank] = cache_get_field_content_int(0, "rank");
    13. frac[playerid][f_type] = cache_get_field_content_int(0, "type");
    14. Iter_Add(iter_fraction, playerid);
    15. }
    16. return true;
    17. }


    В общем, не записываются данные в бд, в mysql_log пишет, что не смог прочитать/записать столбец ai

    1. [00:19:08] [ERROR] CMySQLQuery::Execute[] - (error #1467) Failed to read auto-increment value from storage engine


    В чем может быть проблема?

    https://ibb.co/dMPNZ0k
    Последний раз редактировалось SteveStage; 02.12.2019 в 01:22.

  2. #2
    Аватар для DeimoS
    Модератор?

    Статус
    Оффлайн
    Регистрация
    27.01.2014
    Адрес
    Восточный Мордор
    Сообщений
    5,588
    Репутация:
    1984 ±
    Пересоздай таблицу. Это единственное, что можно посоветовать с той ограниченной информацией, что ты дал.
    А заодно и размер столбца "id" не трогай, ибо это, в любом случае, бессмысленно, так как количество памяти выделится одинаковое количество (что при значении в "11" символов выделится 4 байта, что при значении в "4" символа), а ограничение в 4 символа будет искусственным.
    Связаться со мной в VK можно через личные сообщения этой группы
    Заказы не принимаю

    Широко известно, что идеи стоят 0.8333 цента каждая (исходя из рыночной цены 10 центов за дюжину).
    Великих идей полно, на них нет спроса.
    Воплощение идеи в законченную игру требует долгой работы,
    таланта, терпения и креативности, не говоря уж о затратах денег, времени и ресурсов.
    Предложить идею просто, воплотить – вот в чём проблема

    Steve Pavlina

  3. #3
    Аватар для SteveStage
    Пользователь

    Статус
    Оффлайн
    Регистрация
    05.10.2019
    Адрес
    Планета Земля
    Сообщений
    318
    Репутация:
    7 ±
    Цитата Сообщение от DeimoS Посмотреть сообщение
    Это единственное, что можно посоветовать с той ограниченной информацией, что ты дал.
    Хорошо. Вот OnPlayerConnect:

    1. public OnPlayerConnect(playerid)
    2. {
    3. frac[playerid][f_type] = INVALID_FRACTION_TYPE;
    4. if(!GetPVarInt(playerid, "Animations")) PreloadAnimLib(playerid);
    5. //LOGOTYPE
    6. //ЛОГОТИП
    7. TD_Logo();
    8. //LOGOTYPE SHOW
    9. //ПОКАЗ ЛОГОТИПА
    10. TextDrawShowForAll(td_logo_junction);
    11. TextDrawShowForAll(td_logo_roleplay);
    12. //BAN SYSTEM
    13. //СИСТЕМА БАНА
    14. GetPlayerName(playerid, player_name[playerid], MAX_PLAYER_NAME);
    15. //
    16. new
    17. string[128+1];
    18. mysql_format(connect_mysql, string, sizeof(string), "SELECT * FROM `banlist` WHERE `name` = '%s' LIMIT 1", player_name[playerid]);
    19. mysql_function_query(connect_mysql, string, true, "@_BanCheck", "d", playerid);
    20.  
    21. mysql_format(connect_mysql, string, sizeof(string), "SELECT * FROM `inventory` WHERE `owner` = '%s' LIMIT 1", GetName(playerid));
    22. mysql_function_query(connect_mysql, string, true, "@_LoadInvent", "d", playerid);
    23.  
    24. mysql_format(connect_mysql, string, sizeof(string), "SELECT * FROM `fractions` WHERE `name` = '%s' LIMIT 1", GetName(playerid));
    25. mysql_function_query(connect_mysql, string, true, "@_LoadFrac", "d", playerid);
    26. //
    27. Clear(playerid);
    28. return true;
    29. }


    Вот паблик LoadFrac:

    1. @_LoadFrac(playerid);
    2. @_LoadFrac(playerid)
    3. {
    4. new
    5. rows,
    6. fields;
    7. cache_get_data(rows, fields);
    8. if(rows)
    9. {
    10. cache_get_field_content(0, "name", frac[playerid][f_name], MAX_PLAYER_NAME+1);
    11. frac[playerid][f_id] = cache_get_field_content_int(0, "id");
    12. frac[playerid][f_rank] = cache_get_field_content_int(0, "rank");
    13. frac[playerid][f_type] = cache_get_field_content_int(0, "type");
    14. Iter_Add(iter_fraction, playerid);
    15. }
    16. return true;
    17. }


    Команда выдачи лидерки:

    1. CMD:makeleader(playerid, params[])
    2. {
    3. if(login_check{playerid} == false)
    4. return true;
    5. if(player[playerid][p_admin] == 0)
    6. return SCM(playerid, COLOR_RED, !"Вы не администратор!");
    7. if(player[playerid][p_admin] <= 7)
    8. return SCM(playerid, COLOR_RED, !"Ваш админ-уровень не позволяет вам назначать игроков лидерами организаций!");
    9. new
    10. targetid,
    11. type;
    12. if(sscanf(params, "ud", targetid, type))
    13. return SCM(playerid, COLOR_RED, !"Образец назначения лидера в организацию: /makeleader [id] [type]");
    14. if(!IsPlayerConnected(targetid))
    15. return SCM(playerid, COLOR_RED, !"Игрок с введенным вами ID не в сети!");
    16. if(login_check{targetid} == false)
    17. return SCM(playerid, COLOR_RED, !"Игрок в введенным вами ID не авторизован!");
    18. if(type > MAX_FRACTIONS || type == INVALID_FRACTION_TYPE || type < 0)
    19. return SCM(playerid, COLOR_RED, !"Указан некорректный тип организации!");
    20. new
    21. string[144+1];
    22. format(string, sizeof(string), "Администратор %s назначил игрока %s лидером %s", GetName(playerid), GetName(targetid), frac_list[type]);
    23. SCMTA(COLOR_RED, string);
    24. mysql_format(connect_mysql, string, sizeof(string),
    25. "INSERT INTO `fractions` (`rank`, `type`, `name`) VALUES ('10', '%d', '%s')", type, GetName(targetid));
    26. mysql_function_query(connect_mysql, string, false, "", "");
    27. mysql_format(connect_mysql, string, sizeof(string), "SELECT * FROM `fractions` WHERE `name` = '%s' LIMIT 1", GetName(targetid));
    28. mysql_function_query(connect_mysql, string, true, "@_LoadFrac", "d", targetid);
    29. return true;
    30. }


    frac_list (двумерный массив с названиями фракций):

    1. new frac_list[16][27+1] =
    2. {
    3. "Отсутствует", "Los Santos Police", "San Fierro Police", "Las Venturas Police", "S.W.A.T.", "FBI", "Crips Street Gang", "East Side Bloods", "Latin Kings",
    4. "Nortenos", "Surenos", "Los Santos Medical Center", "San Fierro Medical Center", "Las Venturas Medical Center", "Countryside Sheriff Police",
    5. "Technology Center S.T.A.R."
    6. };


    Энум фракций:

    1. enum E_FRACTION_DATA {
    2. f_name[MAX_PLAYER_NAME+1], f_rank, f_id, f_type
    3. }
    4. new
    5. frac[MAX_PLAYERS][E_FRACTION_DATA];


    Константы:

    1. const
    2. MAX_FRACTIONS = sizeof(frac_list),
    3. INVALID_FRACTION_TYPE = -1;


    Достаточно?
    Последний раз редактировалось SteveStage; 02.12.2019 в 21:11.

  4. #4
    Аватар для Pa4enka
    Пользователь

    Статус
    Оффлайн
    Регистрация
    22.04.2016
    Адрес
    Украина
    Сообщений
    157
    Репутация:
    35 ±
    Могу ошибаться, но вроде столбец с AI должен находится в начале, а не в конце.

    id, name, type, rank.
    Последний раз редактировалось Pa4enka; 02.12.2019 в 17:13.

  5. #5
    Аватар для DeimoS
    Модератор?

    Статус
    Оффлайн
    Регистрация
    27.01.2014
    Адрес
    Восточный Мордор
    Сообщений
    5,588
    Репутация:
    1984 ±
    Цитата Сообщение от Steve_Stage Посмотреть сообщение
    Достаточно?
    Речь была про структуру таблицы, настройки БД и т.п. И я уже дал тебе ответ, который, с вероятностью в 99%, должен исправить проблему.

    Цитата Сообщение от Pa4enka Посмотреть сообщение
    Могу ошибаться, но вроде столбец с AI должен находится в начале, а не в конце.

    id, name, type, rank.
    Нет, никакой зависимости от расположения столбцов нет)
    Связаться со мной в VK можно через личные сообщения этой группы
    Заказы не принимаю

    Широко известно, что идеи стоят 0.8333 цента каждая (исходя из рыночной цены 10 центов за дюжину).
    Великих идей полно, на них нет спроса.
    Воплощение идеи в законченную игру требует долгой работы,
    таланта, терпения и креативности, не говоря уж о затратах денег, времени и ресурсов.
    Предложить идею просто, воплотить – вот в чём проблема

    Steve Pavlina

  6. #6
    Аватар для SteveStage
    Пользователь

    Статус
    Оффлайн
    Регистрация
    05.10.2019
    Адрес
    Планета Земля
    Сообщений
    318
    Репутация:
    7 ±
    Цитата Сообщение от DeimoS Посмотреть сообщение
    И я уже дал тебе ответ, который, с вероятностью в 99%, должен исправить проблему.
    Помогло, лол. Такой тупой способ сработал.

    Но я хотел бы узнать причину такой проблемы.

    Цитата Сообщение от Pa4enka Посмотреть сообщение
    Могу ошибаться, но вроде столбец с AI должен находится в начале, а не в конце.

    id, name, type, rank.
    Всегда создавал первый столбец имя - varchar без ai, и всегда работали запросы.
    Последний раз редактировалось SteveStage; 02.12.2019 в 19:39.

  7. #7
    Аватар для DeimoS
    Модератор?

    Статус
    Оффлайн
    Регистрация
    27.01.2014
    Адрес
    Восточный Мордор
    Сообщений
    5,588
    Репутация:
    1984 ±
    Причин может быть множество. Без информации о настройках таблицы ничего сказать не получится. Если хочется почитать обо всех возможных причинах - гугли текст ошибки и читай :)
    Связаться со мной в VK можно через личные сообщения этой группы
    Заказы не принимаю

    Широко известно, что идеи стоят 0.8333 цента каждая (исходя из рыночной цены 10 центов за дюжину).
    Великих идей полно, на них нет спроса.
    Воплощение идеи в законченную игру требует долгой работы,
    таланта, терпения и креативности, не говоря уж о затратах денег, времени и ресурсов.
    Предложить идею просто, воплотить – вот в чём проблема

    Steve Pavlina

  8. #8
    Аватар для SteveStage
    Пользователь

    Статус
    Оффлайн
    Регистрация
    05.10.2019
    Адрес
    Планета Земля
    Сообщений
    318
    Репутация:
    7 ±
    Цитата Сообщение от DeimoS Посмотреть сообщение
    Причин может быть множество. Без информации о настройках таблицы ничего сказать не получится. Если хочется почитать обо всех возможных причинах - гугли текст ошибки и читай :)
    Впринципе тему можно закрывать, код ошибки есть в посте, кому нужна точная причина: найдёт, кому не нужна - пробуйте пересоздать таблицу, поэтапно указывая ключи/флаги к ней и не отвлекаясь

 

 

Информация о теме

Пользователи, просматривающие эту тему

Эту тему просматривают: 1 (пользователей: 0 , гостей: 1)

Ваши права

  • Вы не можете создавать новые темы
  • Вы не можете отвечать в темах
  • Вы не можете прикреплять вложения
  • Вы не можете редактировать свои сообщения
  •