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

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

    Потеря данных при передаче в MySQL callback

    Еще раз приветствую.
    Знаю открываю много тем, может и не нужных.
    Но по крайне мере ответа на просторах интернета не нашел, может не там искал?
    В общем, проблема в следующем.
    Есть следующий функционал:
    PHP код:
    CMD:banip(playeridparams[]) {
      new 
    query[72];
      new 
    t_ip[18];
      
    GetPlayerIp(playeridt_ipsizeof(t_ip));
      
    mysql_format(MySQLquerysizeof(query), "SELECT * FROM `banned_ip` WHERE `ip` = '%s'"t_ip);
      
    mysql_tquery(MySQLquery"OnBanIPGet""ds"playeridt_ip);
      
    // mysql_tquery(MySQL, query, "OnBanIPGet"); <- Результат идентичен верхенму
      
    return 1;
    }

    forward OnBanIPGet(playeridip);
    public 
    OnBanIPGet(playeridip) {
      new 
    rows cache_num_rows();
      if(
    rows) {
        
    // Он есть
        // Но не показывает не в printf и не в простой SendClientMessage
      
    } else {
        
    // Эго нет + тоже не показывает IP
      
    }

    Как правильно передать данные в этот callback? Что бы они отобразились при проверке в определенном случае.


    И еще один вопросик, допустим если этот адрес найден, и он имеет в БД значение active=1, то как получить это значение, не зная номера строки?

    P.S.: Используется версия мускула R41-2
    P.P.S.: Как-то не охота использовать PVar

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

    Статус
    Оффлайн
    Регистрация
    13.10.2015
    Сообщений
    516
    Репутация:
    21 ±
    Попробуй:

    PHP код:
    forward OnBanIPGet(playeridip);
    public 
    OnBanIPGet(playeridip) {

        new 
    rows;
        
    cache_get_row_count(rows);
          if(
    rows) {
            
    // ip должен быть найден
          
    } else {
            
    // ip не найден
          
    }


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

    Статус
    Оффлайн
    Регистрация
    27.01.2014
    Адрес
    Восточный Мордор
    Сообщений
    5,588
    Репутация:
    1984 ±
    Цитата Сообщение от vladivanovx Посмотреть сообщение
    И еще один вопросик, допустим если этот адрес найден, и он имеет в БД значение active=1, то как получить это значение, не зная номера строки?
    cache_get_value_name
    cache_get_value_name_int
    cache_get_value_name_float
    Связаться со мной в VK можно через личные сообщения этой группы
    Заказы не принимаю

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

    Steve Pavlina

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

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

    PHP код:
    forward OnBanIPGet(playeridip);
    public 
    OnBanIPGet(playeridip) {

        new 
    rows;
        
    cache_get_row_count(rows);
          if(
    rows) {
            
    // ip должен быть найден
          
    } else {
            
    // ip не найден
          
    }

    IP он находит, проблема в том что не отображает его. Даже сохраняет в БД, если его нет. Только вот значение всегда разное (какие-то иероглифы).

    - - - Добавлено - - -
    Цитата Сообщение от DeimoS Посмотреть сообщение
    cache_get_value_name
    cache_get_value_name_int
    cache_get_value_name_float
    Это я знаю, но ведь нужно указать номер строки:
    cache_get_value_name_int
    (row_idx, const column_name[], &destination)
    Последний раз редактировалось vladivanovx; 10.01.2017 в 15:11.

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

    Статус
    Оффлайн
    Регистрация
    24.08.2015
    Адрес
    Ташкент
    Сообщений
    375
    Репутация:
    97 ±
    указываешь 0 ид для строки, а если строк больше, чем 1, то через цикл пробираешь их всех

    PHP код:
    forward OnBanIPGet(playeridip);
    public 
    OnBanIPGet(playeridip) {

        new 
    rows;
        
    cache_get_row_count(rows);
          if(
    rows)
          {
                
    // если 1 строка то ид будет 0
                // а если больше
                
    for(new 0rowsi++)
                {
                     
    //в этом случае ид строки равен i
                
    }
          }
          else 
          {
                
    // если нет строк
          
    }


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

    Статус
    Оффлайн
    Регистрация
    27.01.2014
    Адрес
    Восточный Мордор
    Сообщений
    5,588
    Репутация:
    1984 ±
    Цитата Сообщение от vladivanovx Посмотреть сообщение
    Это я знаю, но ведь нужно указать номер строки:
    cache_get_value_name_int
    (row_idx, const column_name[], &destination)
    Тут указывается ID строки у возвращённых данных.
    Он всегда начинается с нуля.
    Если по запросу вернётся, например, 10 строк, то они займут ID с 0 по 9.
    Связаться со мной в VK можно через личные сообщения этой группы
    Заказы не принимаю

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

    Steve Pavlina

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

    Статус
    Оффлайн
    Регистрация
    11.12.2016
    Сообщений
    27
    Репутация:
    0 ±
    DeimoS,
    Geebrox,

    Аа, большое спасибо.

    - - - Добавлено - - -

    Тогда вернусь к вопросу, по передаче значения ип адреса. Есть ли у кого предположения?

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

    Статус
    Оффлайн
    Регистрация
    24.08.2015
    Адрес
    Ташкент
    Сообщений
    375
    Репутация:
    97 ±
    OnBanIPGet(playerid, ip);

    ты передаешь строку для целочисленного значение???

    OnBanIPGet(playerid, ip[]);

    так будет правильно

  10. #9
    Аватар для vladivanovx
    Пользователь

    Статус
    Оффлайн
    Регистрация
    11.12.2016
    Сообщений
    27
    Репутация:
    0 ±
    Цитата Сообщение от Geebrox Посмотреть сообщение
    OnBanIPGet(playerid, ip);

    ты передаешь строку для целочисленного значение???

    OnBanIPGet(playerid, ip[]);

    так будет правильно
    Переменная ip имеет значение string.
    Попробую ваш вариант, то есть данный тип записи (ip[]) имеет ввиду что передается строка?

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

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

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

    Steve Pavlina

 

 
Страница 1 из 2 1 2 ПоследняяПоследняя

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

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

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

Ваши права

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