Форум программистов, компьютерный форум, киберфорум
PHP: базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.67/3: Рейтинг темы: голосов - 3, средняя оценка - 4.67
4 / 4 / 5
Регистрация: 01.03.2013
Сообщений: 180

Сортировка

21.01.2014, 23:09. Показов 573. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Доброго времени суток.
товары в бд имеют колонки цена и валюта, при создании товара через php добавляется сколько стоит рублей или долларов.
При отображении товаров выбирается по чему сортировать и как (по уб или по возр). Сортировка осуществляется через sql.
Товар на сайте отображается всегда в рублях, даже если при добавлении указывается доллар (делится на курс и все такое).
Проблема в том, что когда указывается сортировка по цене, то она указывается не так, как хотелось. Например у нас есть 4 товара: 1) 1 доллар 2) 2 доллара 3) 3 доллара 4) рубля. Естественно, что по возрастанию должно располагаться как 4)>1)>2)>3). Но так как в sql коде не учитывается, какая валюта, у нас и сортировка идет как 1) 2) 3) 4)
как сделать так, чтоб сортировалось нормально?

PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
    function GetItems($cat1 = 0, $cat2 = 0, $order_by = "id", $order_type = "asc", $limit, $page) {
        global $ODataBase, $GConfig;
        
        # Определяем параметры поиска.
        $order_type = strtoupper($order_type);
        $start = ($page - 1) * $limit;
        
        # Составляем SQL-запрос.
        $sql  = "SELECT * FROM `{$ODataBase->TableName('catalog')}` WHERE ";
        if($cat1 != 0)
            $sql .= "`catalog1` = {$cat1} AND ";
        if($cat2 != 0)
            $sql .= "`catalog2` = {$cat2} AND ";
        $sql .= "`show` = 1 ORDER BY `{$order_by}` {$order_type}";
        if($limit != 0)
            $sql .= " LIMIT {$start},{$limit}";
        $sql .= ";";
. . . . .
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
21.01.2014, 23:09
Ответы с готовыми решениями:

Сортировка
У меня такой вопрос. Есть база данных. В ней таблица. В ней названия марок авто. На странице выводятся марки в ввиде ссылок. Сделанна...

Сортировка
Всем привет, сортировка происходит по нажатию ссылки <a href="co22.php?sortby=brand>Брэнду</a> <a...

Сортировка
Если в адресной строке есть значение для id, вывожу материал где id = GET id. Если есть значение cat из адресной строки, вывожу материал...

1
 Аватар для fanatikus
1932 / 1523 / 703
Регистрация: 17.11.2012
Сообщений: 6,585
23.01.2014, 00:11
в базе нужно хранить цену в одной валюте (а при выводе уже переводить), тогда и с сортировкой не будет проблем
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
23.01.2014, 00:11
Помогаю со студенческими работами здесь

Сортировка
Подскажите, пожалуйста, как правильно организовать сортировку по каждому из полей в таблице БД? Есть таблица type...

Сортировка по дате
Всем привет! Хочу вывести последние поступления в магазин делаю вот такой запрос: select Firm,Model,Price,Link,ImgNm from Notebooks order...

Сортировка списка
В общем есть список (скриншот приложу к вопросу). Запрос выглядит так $myCmd = "SELECT * FROM dlpodrazdeleniya, dldoctor,...

Сортировка в phpMyadmin
Помогите сделать сортировку. Надо сделать сортировку по убыванию и возрастанию. Покажите мне пример с возраст, а убыв я сам сделаю по...

Сортировка по дате
Вывод данных в таблицу. Как сделать так, чтобы при выводе они сортировались по дате (от высшего к низшему). <?php $db =...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
Установка Emscripten SDK (emsdk) и CMake на Windows для сборки C и C++ приложений в WebAssembly (Wasm)
8Observer8 30.01.2026
Чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. Система контроля версиями Git. . .
Подключение Box2D v3 к SDL3 для Android: физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL3_image
8Observer8 27.01.2026
Содержание блога SDL3_image - это библиотека для загрузки и работы с изображениями. Эта пошаговая инструкция покажет, как загрузить и вывести на экран смартфона картинку с альфа-каналом, то есть с. . .
Влияние грибов на сукцессию
anaschu 26.01.2026
Бифуркационные изменения массы гриба происходят тогда, когда мы уменьшаем массу компоста в 10 раз, а скорость прироста биомассы уменьшаем в три раза. Скорость прироста биомассы может уменьшаться за. . .
Воспроизведение звукового файла с помощью SDL3_mixer при касании экрана Android
8Observer8 26.01.2026
Содержание блога SDL3_mixer - это библиотека я для воспроизведения аудио. В отличие от инструкции по добавлению текста код по проигрыванию звука уже содержится в шаблоне примера. Нужно только. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru