Logo Море(!) аналитической информации!
IT-консалтинг Software Engineering Программирование СУБД Безопасность Internet Сети Операционные системы Hardware
Архив форумов ЦИТФорума
Море(!) вопросов - Море(!) ответов
 
 FAQFAQ   ПоискПоиск   ПользователиПользователи   ГруппыГруппы   РегистрацияРегистрация 
 ПрофильПрофиль   Войти и проверить личные сообщенияВойти и проверить личные сообщения   ВходВход 
Как правильно задавать вопросы

Помогите написать select!!!!!!!!!!!!11

 
Перейти:  
Этот форум закрыт, вы не можете писать новые сообщения и редактировать старые.   Эта тема закрыта, вы не можете писать ответы и редактировать сообщения.    Список форумов Архив форумов ЦИТФорума -> Базы данных
Предыдущая тема :: Следующая тема  
Автор Сообщение
Чайник



Зарегистрирован: 08.08.2002
Сообщения: 98
Откуда: Пермь

СообщениеДобавлено: Вт Июн 10 2003 23:11    Заголовок сообщения: Помогите написать select!!!!!!!!!!!!11 Ответить с цитатой

Помогите написать "хороший" select

есть таблица my_table(id,name,create_date)
нужно сделать запрос на все строки с 10 по 20
отсортировывая по дате

Я делаю вот как:

select mt.name
from
my_table mt,
(select v.id, rownum rn
from
(select id from my_table
order by create_date) v
) main_view
where
mt.id = main_view.id and
main_view.rn>10 and main_view.rn
Вернуться к началу
Посмотреть профиль Отправить личное сообщение
Valera
Гость





СообщениеДобавлено: Ср Июн 11 2003 03:43    Заголовок сообщения: Фигня! Нельзя в "хорошем" selecte обращаться к номерам записей напрямую (-) Ответить с цитатой

-
Вернуться к началу
and3008



Зарегистрирован: 12.10.2001
Сообщения: 14893
Откуда: Н.Новгород

СообщениеДобавлено: Ср Июн 11 2003 10:25    Заголовок сообщения: А напрямую никто и не планирует. Нужны диапазоны строк. Ну примерно как в поисковом сервере (-) Ответить с цитатой

-
Вернуться к началу
Посмотреть профиль Отправить личное сообщение
Чайник



Зарегистрирован: 08.08.2002
Сообщения: 98
Откуда: Пермь

СообщениеДобавлено: Ср Июн 11 2003 10:29    Заголовок сообщения: это просто пример блин диапазон задавться будет Ответить с цитатой

-
Вернуться к началу
Посмотреть профиль Отправить личное сообщение
Борис
Гость





СообщениеДобавлено: Ср Июн 11 2003 15:12    Заголовок сообщения: Попробуй (в предположении, что id уникальны) Ответить с цитатой

select *
from (
select top 20 *
from my_table
order by create_date
)
where id not in (
select top 10 id
from my_table
order by create_date
)
;
Вернуться к началу
_
Гость





СообщениеДобавлено: Ср Июн 11 2003 19:37    Заголовок сообщения: А по-моему(+)... Ответить с цитатой

По-моему с если дипазон будет меняться проще написать хранимую процедуру, завести там переменную и наращивая её в ФОРе взять нужный диапазон...
А СЕЛЕКТ сделаешь из хранимой процедуры...
Или надо простой СЕЛЕКТ?..
Вернуться к началу
Чайник



Зарегистрирован: 08.08.2002
Сообщения: 98
Откуда: Пермь

СообщениеДобавлено: Ср Июн 11 2003 20:23    Заголовок сообщения: Ну ты гигант мысли Ответить с цитатой

Ага... а если 1000000 записей в таблице,
то ты их все в процедуре for'ом хранить
будешь. ...

Здесь нужно использовать индексы,
если кто знает как это реализовать
помогите Pls
Вернуться к началу
Посмотреть профиль Отправить личное сообщение
Бочкарев Вячеслав
Гость





СообщениеДобавлено: Пн Июн 16 2003 14:20    Заголовок сообщения: По разному можно сделать. Под какую базу запрос надо? (-) Ответить с цитатой

-
Вернуться к началу
vfdim
Гость





СообщениеДобавлено: Ср Июл 02 2003 09:22    Заголовок сообщения: Re: Помогите написать select!!!!!!!!!!!!11 Ответить с цитатой

select *
from (select rownum rnum ,a.*
from ( select * from [TABLE]) a /*ВАШ_ЗАПРОС -- включая конструкцию order by)*/
where rownum = [N_START]
Вернуться к началу
Показать сообщения:   
Этот форум закрыт, вы не можете писать новые сообщения и редактировать старые.   Эта тема закрыта, вы не можете писать ответы и редактировать сообщения.    Список форумов Архив форумов ЦИТФорума -> Базы данных Часовой пояс: GMT + 3
Страница 1 из 1

 
Перейти:  
Вы не можете начинать темы
Вы не можете отвечать на сообщения
Вы не можете редактировать свои сообщения
Вы не можете удалять свои сообщения
Вы не можете голосовать в опросах


Powered by phpBB © 2001, 2002 phpBB Group
Русская поддержка phpBB

 

IT-консалтинг Software Engineering Программирование СУБД Безопасность Internet Сети Операционные системы Hardware

Информация для рекламодателей PR-акции, размещение рекламы — adv@citforum.ru,
тел. +7 495 6608306, ICQ 232284597
Пресс-релизы — pr@citforum.ru
Послать комментарий
Информация для авторов
This Web server launched on February 24, 1997
Copyright © 1997-2000 CIT, © 2001-2006 CIT Forum
Внимание! Любой из материалов, опубликованных на этом сервере, не может быть воспроизведен в какой бы то ни было форме и какими бы то ни было средствами без письменного разрешения владельцев авторских прав. Подробнее...