169 похожих чатов

А оракл умеет incremental sort? Т.е. я делаю select ... order

by F1, F2, F3, F4,
где F1, F2, F3 входят в индекс (в правильном порядке), а F4 нет. Может ли оракл взять данные в нужном порядке из индекса, а потом досортировать по F4, не пересортировывая всё с начала?

11 ответов

36 просмотров

incremental sort ?

Ilya-Portnov Автор вопроса
zlo
incremental sort ?

ну это в pg оно так называется. В документции оракла не нашёл такой фишки.

Ilya Portnov
ну это в pg оно так называется. В документции орак...

а в чем фишка то, в том что есть оптимизатор ? в оракле типа его нет ?

Ilya-Portnov Автор вопроса
zlo
а в чем фишка то, в том что есть оптимизатор ? в ...

ну вот я пытаюсь выяснить, есть ли конкретно действие incremental sort. Я вполне допускаю что есть, но не вижу на это указаний в интернетах.

Ilya Portnov
ну вот я пытаюсь выяснить, есть ли конкретно дейст...

ну план запроса надо смотреть, что бы увидеть )

Ilya-Portnov Автор вопроса
zlo
а в чем фишка то, в том что есть оптимизатор ? в ...

если известно, что набор данных уже отсортирован по F1, F2, F3, то отсортировать дополнительно по F4 можно быстрее, чем делать сортировку по F1, F2, F3, F4 заново.

Ilya Portnov
если известно, что набор данных уже отсортирован п...

чуть выше написал - надо посмотреть план запроса. зы

Ilya-Portnov Автор вопроса
zlo
ну план запроса надо смотреть, что бы увидеть )

------------------------------------------------------------ | Id | Operation | Name | Starts | E-Rows |E-Bytes|E-Temp | Cost (%CPU)| E-Time | Pstart| Pstop | A-Rows | A-Time | Buffers | Reads | Writes | OMem | 1Mem | O/1/M | Max-Tmp | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | 0 | SELECT STATEMENT | | 2 | | | | 889K(100)| | | | 100 |00:00:13.20 | 1918K| 314K| 32736 | | | | | | 1 | FAST DUAL | | 2 | 1 | | | 2 (0)| 00:00:01 | | | 2 |00:00:00.01 | 0 | 0 | 0 | | | | | |* 2 | VIEW | | 2 | 50 | 254K| | 889K (1)| 00:00:35 | | | 100 |00:00:13.20 | 1918K| 314K| 32736 | | | | | |* 3 | COUNT STOPKEY | | 2 | | | | | | | | 100 |00:00:13.20 | 1918K| 314K| 32736 | | | | | | 4 | VIEW | | 2 | 1018K| 5058M| | 889K (1)| 00:00:35 | | | 100 |00:00:13.20 | 1918K| 314K| 32736 | | | | | ... 5 - (#keys=4) INTERNAL_FUNCTION("DBP_T1"."ACCOUNTID")[22], INTERNAL_FUNCTION("DBP_T1"."OPERDAY")[7], INTERNAL_FUNCTION("DBP_T1"."POSTINGSEQ")[22], "DBP_T1".ROWID[ROWID,10], "DBP_T1"."ID"[NUMBER,22], "DBP_T1"."TRANID"[NUMBER,22], [4000], "DBP_T4"."SEQ"[NUMBER,22], "DBP_T4"."ENTRYSEQ"[NUMBER,22], "DBP_T1"."ENTRYSEQ"[NUMBER,22], "DBP_T1"."ENTRYPARTSEQ"[NUMBER,22], "DBP_T1"."ENTRYKIND"[VARCHAR2,400], "DBP_T1"."FINOPERKIND"[VARCHAR2,400], "DBP_T1"."REGISTERROLE"[VARCHAR2,400], "DBP_T1"."CLASSIFICATION"[VARCHAR2,4000], "DBP_T1"."SIGN"[NUMBER,22], "DBP_T1"."AMT"[NUMBER,22], "DBP_T1"."BASEAMT"[NUMBER,22], "DBP_T2"."ID"[NUMBER,22], "DBP_T2"."KIND"[VARCHAR2,400], "DBP_T2"."LIFEPHASE"[VARCHAR2,200], "DBP_T3"."ID"[NUMBER,22], "DBP_T3"."NUMBER_"[VARCHAR2,200], "DBP_T4"."TRANID"[NUMBER,22]

Ilya Portnov
ну это в pg оно так называется. В документции орак...

Да, есть, и есть спец трассировка сортировки даже - 10032

Похожие вопросы

Обсуждают сегодня

30500 за редактор? )
Владимир
47
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
вы делали что-то подобное и как? может есть либы готовые? увидел картинку нокода, где всё линиями соединено и стало интересно попробовать то же в ddl на lua сделать. решил с ч...
Victor
8
Подскажите пожалуйста, как в CustomDrawCell(Sender: TcxCustomGridTableView; ACanvas: TcxCanvas; AViewInfo: TcxGridTableDataCellViewInfo; var ADone: Boolean); получить наз...
A Z
7
Ребят в СИ можно реализовать ООП?
Николай
33
https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_h_common.erl#L174 https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_olp.erl#L76 15 лет назад...
Maksim Lapshin
20
Как передать управляющий символ в открытую через CreateProcess консоль? Собсна, есть процедура: procedure TRedirectThread.WriteData(Data: OEMString); var Written: Cardinal;...
Serjone
1
Он в одиночку это дело запилил или была какая-то команда?
Aquinary
12
~ 2m21s  nix shell github:nixos/nixpkgs#stack ~  stack ghc -- --version error: … while calling the 'derivationStrict' builtin at /builtin/derivation.nix:...
Rebuild your mind.
6
Всем привет, нужна как никогда, нужна помощь с IO в загрузчике. Пишу в code16 после установки сегментных регистров, пишу вывод символа. Пробовал 2 варианта: # 1 mov $0x0E, %a...
Shadow Akira
14
Карта сайта