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

    Статус
    Оффлайн
    Регистрация
    22.04.2013
    Адрес
    Краснодар
    Сообщений
    292
    Репутация:
    23 ±

    Как при помощи запроса MySQL узнать сумму всех значений определённого столбца?

    Представим, что у меня есть фракция, которая создается динамически. Я хочу сделать рейтинги и не могу додуматься как будет выглядеть запрос.

    Мне нужно все игроки, которые причастны к моей фракции, найти их по переменной pFrac и узнать у каждого их Level и сплюсовать его в едино.

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

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

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

    Steve Pavlina

  3. Пользователь сказал cпасибо:
    DmX (03.07.2017)
  4. #3
    Аватар для DmX
    Пользователь

    Статус
    Оффлайн
    Регистрация
    22.04.2013
    Адрес
    Краснодар
    Сообщений
    292
    Репутация:
    23 ±
    Выборка будет так. Есть таблица account, там есть переменная pFrac (Это соответственно переменная ИД фракции), нужно найти игроков всех, кто имеет к примеру pFrac = 1, и посчитать их общий Уровень (pLevel). (Всех игроков и онлайн и оффлайн).

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

    Статус
    Оффлайн
    Регистрация
    27.01.2014
    Адрес
    Восточный Мордор
    Сообщений
    5,588
    Репутация:
    1984 ±
    PHP код:
    SELECT SUM(pLevel) AS result FROM account WHERE pFrac = %
    Результат приходит в виде столбца с именем "result"
    Последний раз редактировалось DeimoS; 03.07.2017 в 18:17.
    Связаться со мной в VK можно через личные сообщения этой группы
    Заказы не принимаю

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

    Steve Pavlina

  6. Пользователь сказал cпасибо:
    DmX (03.07.2017)
  7. #5
    Аватар для DmX
    Пользователь

    Статус
    Оффлайн
    Регистрация
    22.04.2013
    Адрес
    Краснодар
    Сообщений
    292
    Репутация:
    23 ±
    Цитата Сообщение от DeimoS Посмотреть сообщение
    PHP код:
    SELECT SUM(pLevel) AS result FROM account WHERE pFrac = %
    Результат приходит в виде столбца с именем "result"
    Не мог бы ты показать как на примере это использовать? С выводом результата

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

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

    PHP код:
    new Cache:result mysql_query(переменная"SELECT SUM(pLevel) AS result FROM account WHERE pFrac = 10"true);//У тебя, соответственно, запрос не вписан сразу, а форматируется, вставляя ID нужной фракции
    if(!cache_get_row_count())
    {
        
    cache_delete(result);
        return 
    /*фракция не найдена*/;
    }
    new 
    count cache_get_field_content_int(0"result");
    cache_delete(result);
    printf("Результат: %d"count); 
    Связаться со мной в VK можно через личные сообщения этой группы
    Заказы не принимаю

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

    Steve Pavlina

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

    Статус
    Оффлайн
    Регистрация
    22.04.2013
    Адрес
    Краснодар
    Сообщений
    292
    Репутация:
    23 ±
    Цитата Сообщение от DeimoS Посмотреть сообщение
    Та бож, чего сложного-то в моём объяснении?

    PHP код:
    new Cache:result mysql_query(переменная"SELECT SUM(pLevel) AS result FROM account WHERE pFrac = 10"true);//У тебя, соответственно, запрос не вписан сразу, а форматируется, вставляя ID нужной фракции
    if(!cache_get_row_count())
    {
        
    cache_delete(result);
        return 
    /*фракция не найдена*/;
    }
    new 
    count cache_get_field_content_int(0"result");
    cache_delete(result);
    printf("Результат: %d"count); 
    А как форматировать?

    PHP код:
    new Cache:result mysql_format(MYSQL_ARGasdsizeof(asd), "SELECT SUM(pLevel) AS result FROM account WHERE pFrac = %d"FamInfo[PlayerInfo[playerid][pFrac]-1][fID]);

    warning 213tag mismatch 
    - - - Добавлено - - -

    Цитата Сообщение от Nash_Brigers Посмотреть сообщение
    Одеться тебе нужно
    offtop off

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

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

    PHP код:
    new Cache:result mysql_format(MYSQL_ARGasdsizeof(asd), "SELECT SUM(pLevel) AS result FROM account WHERE pFrac = %d"FamInfo[PlayerInfo[playerid][pFrac]-1][fID]);

    warning 213tag mismatch 
    У меня вопрос: как ты вообще пишешь мод с использованием MySQL, если не понимаешь таких элементарных вещей, как формирование запроса?
    И зачем там mysql_format?

    PHP код:
    format(asdsizeof(asd), "SELECT SUM(pLevel) AS result FROM account WHERE pFrac = %d"FamInfo[PlayerInfo[playerid][pFrac]-1][fID]);
    new 
    Cache:result mysql_query(MYSQL_ARGasdtrue);//У тебя, соответственно, запрос не вписан сразу, а форматируется, вставляя ID нужной фракции
    if(!cache_get_row_count())
    {
        
    cache_delete(result);
        return 
    /*фракция не найдена*/;
    }
    new 
    count cache_get_field_content_int(0"result");
    cache_delete(result);
    printf("Результат: %d"count); 
    Связаться со мной в VK можно через личные сообщения этой группы
    Заказы не принимаю

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

    Steve Pavlina

  12. Пользователь сказал cпасибо:
    DmX (03.07.2017)
  13. #9
    Аватар для DmX
    Пользователь

    Статус
    Оффлайн
    Регистрация
    22.04.2013
    Адрес
    Краснодар
    Сообщений
    292
    Репутация:
    23 ±
    Цитата Сообщение от DeimoS Посмотреть сообщение
    У меня вопрос: как ты вообще пишешь мод с использованием MySQL, если не понимаешь таких элементарных вещей, как формирование запроса?
    И зачем там mysql_format?

    PHP код:
    format(asdsizeof(asd), "SELECT SUM(pLevel) AS result FROM account WHERE pFrac = %d"FamInfo[PlayerInfo[playerid][pFrac]-1][fID]);
    new 
    Cache:result mysql_query(MYSQL_ARGasdtrue);//У тебя, соответственно, запрос не вписан сразу, а форматируется, вставляя ID нужной фракции
    if(!cache_get_row_count())
    {
        
    cache_delete(result);
        return 
    /*фракция не найдена*/;
    }
    new 
    count cache_get_field_content_int(0"result");
    cache_delete(result);
    printf("Результат: %d"count); 
    Не каждый день пишу скрипты с использованием Mysql. Нарабатывал опыт еще в 2008. На файловых системах. Спасибо DeimoS выручил.

 

 

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

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

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

Ваши права

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