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

    Статус
    Оффлайн
    Регистрация
    26.11.2016
    Сообщений
    14
    Репутация:
    0 ±

    Переменная не сохраняет значение cache_insert_id

    Доброго времени суток. Я не первый день, пытаюсь вытащить последний ид, сгенерированный AUTO_INCREMENT из БД. Но выходит лишь вывести его в консоль:
    PHP код:
    format(querysizeof(query), "INSERT INTO `Battle` (type) VALUES ('1')");
    mysql_function_query(connectsquery"test""i");

    public 
    test()
    {
        
    printf("%d",cache_insert_id());//этот момент срабатывает
        
    idB cache_insert_id();//а этот нет
         
    return 1;

    Буду весьма признателен, если вы подскажите, что я делаю не так.

  2. #2
    Аватар для Redsan
    Пользователь

    Статус
    Оффлайн
    Регистрация
    07.06.2016
    Адрес
    Minsk, Belarus
    Сообщений
    78
    Репутация:
    15 ±
    Как объявлена переменная idB? Как вы проверяете записанный в нее id?

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

    Статус
    Оффлайн
    Регистрация
    26.11.2016
    Сообщений
    14
    Репутация:
    0 ±
    Цитата Сообщение от Redsan Посмотреть сообщение
    Как объявлена переменная idB? Как вы проверяете записанный в нее id?
    PHP код:
    new idB;

    format(probtxtsizeof(probtxt), "n %d " idB);
    SendClientMessage(iCOLOR_WHITEprobtxt); 

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

    Статус
    Оффлайн
    Регистрация
    07.06.2016
    Адрес
    Minsk, Belarus
    Сообщений
    78
    Репутация:
    15 ±
    Цитата Сообщение от Danil_Cage Посмотреть сообщение
    PHP код:
    new idB;

    format(probtxtsizeof(probtxt), "n %d " idB);
    SendClientMessage(iCOLOR_WHITEprobtxt); 
    Так должно работать:
    PHP код:
    new probtxt[11];
    format(probtxtsizeof(probtxt), "n %d"idB);
    SendClientMessage(iCOLOR_WHITEprobtxt); 

  5. #5
    Аватар для Danil_Cage
    Пользователь

    Статус
    Оффлайн
    Регистрация
    26.11.2016
    Сообщений
    14
    Репутация:
    0 ±
    Цитата Сообщение от Redsan Посмотреть сообщение
    Так должно работать:
    PHP код:
    new probtxt[11];
    format(probtxtsizeof(probtxt), "n %d"idB);
    SendClientMessage(iCOLOR_WHITEprobtxt); 
    у меня безусловно имеется
    PHP код:
    new probtxt[11]; 
    просто я счёл, что нет необходимости это отправлять в виду того, что без данного массива я просто не смог бы скомпилировать мод.

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

    Статус
    Оффлайн
    Регистрация
    27.01.2014
    Адрес
    Восточный Мордор
    Сообщений
    5,588
    Репутация:
    1984 ±
    ???

    PHP код:
    format(querysizeof(query), "INSERT INTO `Battle` (type) VALUES ('1')"); 
    mysql_function_query(connectsquery"test""i"); 

    public 
    test() 

        
    idB cache_insert_id();
        
    printf("%d"idB);//этот момент срабатывает 
         
    return 1

    Связаться со мной в VK можно через личные сообщения этой группы
    Заказы не принимаю

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

    Steve Pavlina

  7. Пользователь сказал cпасибо:
    Danil_Cage (18.03.2017)
  8. #7
    Аватар для Danil_Cage
    Пользователь

    Статус
    Оффлайн
    Регистрация
    26.11.2016
    Сообщений
    14
    Репутация:
    0 ±
    Цитата Сообщение от DeimoS Посмотреть сообщение
    ???

    PHP код:
    format(querysizeof(query), "INSERT INTO `Battle` (type) VALUES ('1')"); 
    mysql_function_query(connectsquery"test""i"); 

    public 
    test() 

        
    idB cache_insert_id();
        
    printf("%d"idB);//этот момент срабатывает 
         
    return 1

    К великому сожалению, данный вариант тоже не помогает. idB просто не принимает значение.

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

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

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

    Steve Pavlina

  10. Пользователь сказал cпасибо:
    Danil_Cage (18.03.2017)
  11. #9
    Аватар для Danil_Cage
    Пользователь

    Статус
    Оффлайн
    Регистрация
    26.11.2016
    Сообщений
    14
    Репутация:
    0 ±
    Цитата Сообщение от DeimoS Посмотреть сообщение
    Дай полный код того, как всё обстоит сейчас (включая запрос, объявление переменных и т.п.)
    PHP код:
    new idB;
    format(querysizeof(query), "INSERT INTO `Battle` (type) VALUES ('1')"); 
    mysql_function_query(connectsquery"test""i");

    new 
    probtxt[144];//извиняюсь за магию
    format(probtxtsizeof(probtxt), "n %d "idB);
    SendClientMessage(iCOLOR_WHITEprobtxt);

    public 
    test() 

        
    idB cache_insert_id();
        
    printf("%d"idB);//этот момент срабатывает 
         
    return 1


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

    Статус
    Оффлайн
    Регистрация
    27.01.2014
    Адрес
    Восточный Мордор
    Сообщений
    5,588
    Репутация:
    1984 ±
    Всё дело в том, что ты используешь запрос, который будет обрабатываться MySQL в отдельном потоке и из-за этого вот этот код:
    PHP код:
    new probtxt[144];
    format(probtxtsizeof(probtxt), "n %d "idB);
    SendClientMessage(iCOLOR_WHITEprobtxt); 
    Обработается раньше, нежели MySQL вернёт данные о созданной строке => ID строки ещё не запишется в переменную.
    Нужно использовать однопоточный запрос в этом случае:

    PHP код:
    new idB;
    format(querysizeof(query), "INSERT INTO `Battle` (type) VALUES ('1')"); 
    mysql_query(connectsquery);
    idB cache_insert_id();

    new 
    probtxt[144];
    format(probtxtsizeof(probtxt), "n %d "idB);
    SendClientMessage(iCOLOR_WHITEprobtxt); 
    Связаться со мной в VK можно через личные сообщения этой группы
    Заказы не принимаю

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

    Steve Pavlina

  13. Пользователь сказал cпасибо:
    Danil_Cage (18.03.2017)
 

 

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

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

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

Ваши права

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