Форум Flasher.ru
Ближайшие курсы в Школе RealTime
Список интенсивных курсов: [см.]  
  
Специальные предложения: [см.]  
  
 
Блоги Правила Справка Пользователи Календарь Сообщения за день
 

Вернуться   Форум Flasher.ru > Архив Flasher.ru > Программирование > PHP

Версия для печати  Отправить по электронной почте    « Предыдущая тема | Следующая тема »  
Опции темы Опции просмотра
 
Создать новую тему  
Старый 29.09.2001, 23:03
Froggy вне форума Посмотреть профиль Отправить личное сообщение для Froggy Найти все сообщения от Froggy
  № 1  
Froggy
 
Аватар для Froggy

Регистрация: Sep 2001
Адрес: россия, Краснодар
Сообщений: 157
Отправить сообщение для Froggy с помощью ICQ
Question Как вывести список авторов по алфивиту

ГУРУ! Надобна от Вас помощь. Есть список авторов статей в БД-мускулов, как вывести этот список по алфавиту, т.е. "А" - ...авторы, "Б" - ...авторы, и т.д. короче типа как оглавления делаются. Т.е. как Я понимаю нужно специфически цикл сбацать, но мозгов не хватает. Буду признателен за помощь. С Уважением Андрей. Пишите на почту: froggy@tsrv.ru или jaba@kmivc.kubannet.ru.
__________________
FROGGY: ничто так не обманчиво, как слишком очевидные факты...

Старый 30.09.2001, 11:00
DeepDiver вне форума Посмотреть профиль Отправить личное сообщение для DeepDiver Найти все сообщения от DeepDiver
  № 2  
DeepDiver

Регистрация: Oct 2000
Адрес: Подмосковье
Сообщений: 637
Отправить сообщение для DeepDiver с помощью ICQ
Проблем нет, елси у тебя мускул русифицированный. Тогда просто в запросе добавляешь " select ... from ... where ... order by name;"
Но, к сожалению не все коту масленица. В таком случае приходится сортировать самому.
Для этого заливаешь всю выборку из таблицы в ассоциативный массив и сортируешь уже массив, а потом выводишь, как тебе надо.
Пример:
Код:
// Для начала считываем всю выборку в двумерный массив
$r = mysql_query("select name1,name2 from authors;");
$a = array();
while (list($name1,$name2)=mysql_fetch_row($r)){
  $a[] = array($name1,$name2);
};


//Поскольку сортировка производится не совсем обычная,
//приходится писать еще и функцию сравнения двух элементов
funciton sort_func($a,$b){
 // Каждый элемент - сам по себе массив из двух элементов
 // Для полной алфавитной сортировки надобно соединить
 // имя с фамилией
 return strcmp($a[0].$a[1], $b[0].$b[1]);
};


//Затем сортируем  с использованием нашей функции
usort($a, sort_func);
После все этих манипуляций массив $a будет отсортирован в алфавитном порядке. Ну а как вывести его по буквам - надеюсь додумаешься
Надо либо просто запоминать первую букву выводимой фамилии, и по мере вывода следить, когда она изменится
__________________
Не ошибается то, что не работает. (с) Windows

Старый 30.09.2001, 22:43
Froggy вне форума Посмотреть профиль Отправить личное сообщение для Froggy Найти все сообщения от Froggy
  № 3  
Froggy
 
Аватар для Froggy

Регистрация: Sep 2001
Адрес: россия, Краснодар
Сообщений: 157
Отправить сообщение для Froggy с помощью ICQ
Attention Да уж...

Мускул у Меня не русский и поэтому не сортирует. Спасибо за помощь поковыряюсь с твоей подсказкой
__________________
FROGGY: ничто так не обманчиво, как слишком очевидные факты...

Старый 02.10.2001, 23:34
Froggy вне форума Посмотреть профиль Отправить личное сообщение для Froggy Найти все сообщения от Froggy
  № 4  
Froggy
 
Аватар для Froggy

Регистрация: Sep 2001
Адрес: россия, Краснодар
Сообщений: 157
Отправить сообщение для Froggy с помощью ICQ
Attention Руссификация Мускулов

Да кстати. Руссификация MySQL заключается в том чтобы научить его распознавать русские символы при работе с базами по запросам. А делается это, как Я выяснил, просто. Надо только выставить Charsets по умолчанию не latin1, кот. устанавливается при интсталляции, а cp1251(именно cp1251 а не win1251).
__________________
FROGGY: ничто так не обманчиво, как слишком очевидные факты...

Старый 03.10.2001, 11:29
Geoserg вне форума Посмотреть профиль Отправить личное сообщение для Geoserg Найти все сообщения от Geoserg
  № 5  
Geoserg

Регистрация: Mar 2001
Адрес: Петрозаводск
Сообщений: 44
---------------------------------------------------------------------------------
Да кстати. Руссификация MySQL заключается в том чтобы научить его распознавать русские символы при работе с базами по запросам. А делается это, как Я выяснил, просто. Надо только выставить Charsets по умолчанию не latin1, кот. устанавливается при интсталляции, а cp1251(именно cp1251 а не win1251).
---------------------------------------------------------------------------------

Ага, а если хостинг западный? Насколько я помню, CP можно указывать прямо в запросе. Но если есть возможность, то конечно проще поставить cp1251 по умолчанию.

Создать новую тему   Часовой пояс GMT +4, время: 05:11.
Быстрый переход
  « Предыдущая тема | Следующая тема »  

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

BB коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.


 


Часовой пояс GMT +4, время: 05:11.


Copyright © 1999-2008 Flasher.ru. All rights reserved.
Работает на vBulletin®. Copyright ©2000 - 2026, Jelsoft Enterprises Ltd. Перевод: zCarot
Администрация сайта не несёт ответственности за любую предоставленную посетителями информацию. Подробнее см. Правила.