Добро пожаловать на Pro Pawn - Портал о PAWN-скриптинге.
Показано с 1 по 4 из 4

Тема: Mysql

  1. #1
    Аватар для DelAccount
    Пользователь

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

    Mysql

    Такой вопрос уже был на форуме давно, но решения на него по сей день нет.


    Нужна система на MySQL с перелистыванием страниц, то есть в диалоге 10 записей выгрузило жмешь след страница, и тебе ещё 10 показывает... И в загаловке диалога показывать какая страница открыта, если открыта > 1 то кнопка след страница должна меняться на пред страница.
    У кого какие мысли по этому поводу?

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

    Статус
    Оффлайн
    Регистрация
    27.01.2014
    Адрес
    Восточный Мордор
    Сообщений
    5,588
    Репутация:
    1984 ±
    Эмм, касаемо SQL - всё просто
    PHP код:
    SELECT FROM имя_таблицы WHERE условие LIMIT с_какой_строки_выгружатьсколько_строк_выгружать 
    То бишь
    PHP код:
    SELECT FROM users WHERE money 5 LIMIT 510 
    такой запрос сначала найдёт все строки, которые подходят под условие "money > 5", после пропустит первые 5 строк и выгрузит следующие 10 (с 5-ой по 15-ую строки).




    Главное понимай, что такой запрос сначала ищет строки по условию (срабатывает "money > 5"), а потом уже из этих строк выбирает нужные (срабатывает "LIMIT 5, 10")




    В твоём случае нужно просто хранить в памяти номер открытой страницы и подставлять его в запрос
    PHP код:
    "SELECT * FROM имя_таблицы WHERE условие LIMIT %d*10, 10"переменная_с_номером_страницы 
    Последний раз редактировалось DeimoS; 28.09.2016 в 05:21.
    Связаться со мной в VK можно через личные сообщения этой группы
    Заказы не принимаю

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

    Steve Pavlina

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

    Статус
    Оффлайн
    Регистрация
    19.09.2016
    Сообщений
    10
    Репутация:
    0 ±
    С самим запросом в принципе проблем нет, дело в том, что поиск идет еще и по слову (вместо money > 5 ищет слово в столбце и выгружает через цикл все найденные строки) командой /команда (текст) (страница). Сам запрос работает, а вот как хранить все это в памяти и потом делать запрос по новой в диалоге не совсем понимаю. То есть нужно хранить текст и страницу в пваре или глобальной переменной и в диалоге вызвать команду с этими параметрами, но к странице прибавить нужное значение?

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

    Статус
    Оффлайн
    Регистрация
    27.01.2014
    Адрес
    Восточный Мордор
    Сообщений
    5,588
    Репутация:
    1984 ±
    Цитата Сообщение от DelAccount Посмотреть сообщение
    С самим запросом в принципе проблем нет, дело в том, что поиск идет еще и по слову (вместо money > 5 ищет слово в столбце и выгружает через цикл все найденные строки) командой /команда (текст) (страница). Сам запрос работает, а вот как хранить все это в памяти и потом делать запрос по новой в диалоге не совсем понимаю. То есть нужно хранить текст и страницу в пваре или глобальной переменной и в диалоге вызвать команду с этими параметрами, но к странице прибавить нужное значение?
    Ну я бы сделал как-то так:
      Открыть/закрыть
    PHP код:
    CMD:list(playeridparams[])
    {
        if(
    isnull(params)) 
            return 
    SendClientMessage(playerid, -1"/list <Номер страницы> <Текст>");

        new 
    page_number;
        
    sscanf(params"is[31]"page_numberparams);

        if(
    page_number <= 1page_number 0;
        else 
    page_number-=1;

        if(
    strlen(params) > 30)
            return 
    SendClientMessage(playerid, -1"Текст не может быть больше 30 символов");

        
    SetPVarInt(playerid"PageNumber"page_number);

    /*
        В запросе возвращаем не 10 строк, а 11, дабы понять, выгрузили ли мы этим запросом все данные из таблицы
        или осталось что-то ещё.

        Когда уже начнём работать с кэшем, работать будем лишь с 10-ю строками, а 11-ую трогать не будем. 
        Она нам нужна лишь для того, чтоб понять, нужно ли добавлять "Далее"
    */

        
    new query_string[39+30+10+1];
        
    format(query_stringsizeof(query_string), "SELECT * FROM users WHERE string = '%s' LIMIT %i, 11"paramspage_number*10);
        
    mysql_tquery(connectionHandlequery_string"MysqlListForPlayer""ii"playeridpage_number);
        return 
    1;

    PHP код:
    forward MysqlListForPlayer(playeridpage_number);
    public 
    MysqlListForPlayer(playeridpage_number)
    {
        new 
    string[...],
            
    row_count;

        
    cache_get_row_count(row_count);

        switch(
    row_count)
        {
            case 
    0:
                return 
    SendClientMessage(playerid, -1"Запрос вернул пустой результат (строк с указанным текстом не найдено)");
            case 
    1:
            {
                
    cache_get_value_name(0"column_name"string_destinationmax_len);
                
    cache_get_value_name_int(0"column_name"int_destination);
                
    cache_get_value_name_float(0"column_name"float_destination);

                
                
    format(stringsizeof(string), "%s %d %f"string_destinationint_destinationfloat_destination);
                
            }
            default:
            {
                new 
    = (row_count 10 10 row_count);
                for(new 
    ipi++)
                {
                    
    cache_get_value_name(i"column_name"string_destinationmax_len);
                    
    cache_get_value_name_int(i"column_name"int_destination);
                    
    cache_get_value_name_float(i"column_name"float_destination);

                    
                    
    format(stringsizeof(string), "%s%s %d %f\n"stringstring_destinationint_destinationfloat_destination);
                }
            }
        }

        switch(
    page_number)
        {
            case 
    0: {}
            case 
    1strcat(string"Назад");
            default:
            {
                
    strcat(string"Назад");
                if(
    row_count 10strcat(string"\nДалее");
            }
        }
        return 
    ShowPlayerDialog(playerid666DIALOG_STYLE_LIST"caption"string"Выбрать""Закрыть");

    PHP код:
    public OnDialogResponse(playeriddialogidresponselistiteminputtext[])
    {
        switch(
    dialogid)
        {
            case 
    666:
            {
                if(!
    response)
                {
                    
    DeletePVar(playerid"PageNumber");
                    return 
    1;
                }

                new 
    page_number = -1;

                if(!
    strcmp(inputtext"Назад"false))
                {
                    
    page_number GetPVarInt(playerid"PageNumber")-1;
                        
                }
                else if(!
    strcmp(inputtext"Далее"false))
                {
                    
    page_number GetPVarInt(playerid"PageNumber")+1;
                }
                else
                {
                    switch(
    listitem)
                    {
                        case 
    0
                        {
    //                        Действие
                        
    }
                        case 
    1
                        {
    //                        Действие
                        
    }
                        case 
    2
                        {
    //                        Действие
                        
    }
    //                    ...
                    
    }
                }

                if(
    page_number != -&& page_number != GetPVarInt(playerid"PageNumber"))
                {
                    
    SetPVarInt(playerid"PageNumber"page_number);
                    new 
    query_string[39+30+10+1];
                    
    format(query_stringsizeof(query_string), "SELECT * FROM users WHERE string = '%s' LIMIT %i, 11"paramspage_number*10);
                    
    mysql_tquery(connectionHandlequery_string"MysqlListForPlayer""ii"playeridpage_number);
                }
                return 
    1;
            }
        }
        return 
    1;



    На работоспособность не проверял
    Последний раз редактировалось DeimoS; 28.09.2016 в 15:47.
    Связаться со мной в VK можно через личные сообщения этой группы
    Заказы не принимаю

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

    Steve Pavlina

 

 

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

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

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

Ваши права

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