|
|
|
Как быстро найти запись с заданным порядковым номером
|
|||
|---|---|---|---|
|
#18+
Нужно найти запись в табл. с заданным порядковым номером, пишу запрос select ID from Tabl Q1 where :RECNO = (select count(*) from Tabl Q2 where Q2.ID <= Q1.ID) into :ID; Но на моей табл. на 2000 записей это зависает секунд на 15. Может есть другие средства, чтобы скорость увеличить ? ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 27.10.2003, 15:03 |
|
||
|
Как быстро найти запись с заданным порядковым номером
|
|||
|---|---|---|---|
|
#18+
В firebird SELECT FIRST 1 SKIP (:RECNO) ... В Interbase - не знаю. Смотри синтаксис ROWS ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 27.10.2003, 15:24 |
|
||
|
Как быстро найти запись с заданным порядковым номером
|
|||
|---|---|---|---|
|
#18+
А вот нет в Intebase, FireBird, Yaffil и проч. порядковых номеров! И не было никогда! Пользуйтесь поиском по ключу. Учите SQL. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 27.10.2003, 16:09 |
|
||
|
Как быстро найти запись с заданным порядковым номером
|
|||
|---|---|---|---|
|
#18+
select ID from Tabl Q1 where :RECNO = (select count(*) from Tabl Q2 where Q2.ID <= Q1.ID) into :ID; это что за страх? ну напиши ХП если уж очень надо. скорость увеличится в сотни раз. типа такого*пишу на ходу) Код: plaintext 1. 2. 3. 4. 5. 6. 7. 8. 9. 10. 11. 12. 13. 14. 15. 16. 17. если данных много можно сделать проверку типа Код: plaintext 1. 2. 3. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 27.10.2003, 17:06 |
|
||
|
Как быстро найти запись с заданным порядковым номером
|
|||
|---|---|---|---|
|
#18+
верно сказано "Учите SQL"... мне вот интересно как генерируются эти самые "порядковые номера"? ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 28.10.2003, 03:09 |
|
||
|
Как быстро найти запись с заданным порядковым номером
|
|||
|---|---|---|---|
|
#18+
Триггер на инсерт + генератор (учите SQL) ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 28.10.2003, 06:27 |
|
||
|
Как быстро найти запись с заданным порядковым номером
|
|||
|---|---|---|---|
|
#18+
nik_x я думаю я его маленько знаю.... ну скажем на достаточном уровне, по крайней мере версию IB... далее, а в курсе ли Вы, молодой человек, о том что если было получено новое значение генератора, то даже в случае отката транзакции генератор не вернется на свое место? А порядковые номера, это в моем понимании последовательность натуральных чисел без пропусков ... Это так на всякий случай... Да и еще, исключительно для Вашего развития, в Oracle не гарантируется что номера будут идти строго последовательно. Гарантируется лишь только что они уникальны. Так что, я позволю себе посоветовать в Ваш адрес не распальцовываться... ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 29.10.2003, 03:14 |
|
||
|
|

start [/forum/topic.php?fid=40&fpage=499&tid=1579743]: |
0ms |
get settings: |
7ms |
get forum list: |
17ms |
check forum access: |
3ms |
check topic access: |
3ms |
track hit: |
51ms |
get topic data: |
12ms |
get forum data: |
3ms |
get page messages: |
43ms |
get tp. blocked users: |
1ms |
| others: | 213ms |
| total: | 353ms |

| 0 / 0 |
