powered by simpleCommunicator - 2.0.53     © 2025 Programmizd 02
Форумы / Oracle [игнор отключен] [закрыт для гостей] / 10.2.0.5, ASMM, CLOB
4 сообщений из 4, страница 1 из 1
10.2.0.5, ASMM, CLOB
    #39780579
Деев И.
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Гость
Добрый день!
Вдруг у кого-то есть под рукой Oracle 10.2.0.5 с работающим ASMM, желательно под Linux x86 64-bit
Хотел бы попросить выполнить простой скрипт и привести результат, если не сложно.
Был бы благодарен.

Код: plsql
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
16.
17.
18.
19.
20.
21.
22.
23.
24.
25.
26.
27.
28.
29.
30.
31.
-- 10.2.0.5?
select * from v$version;

-- Проверка использваония ASMM 
select * from v$system_parameter p where p.name = 'sga_target'; -- !=0

-- Тест по формированию CLOB
declare
  l_clob clob;
  l_t1 number;
  l_t2 number;
begin
  -- test 1
  l_t1 := dbms_utility.get_time;
  for i in 1..100 loop
      l_clob := l_clob || rpad('1',32000);
  end loop;
  l_t2 := dbms_utility.get_time;
  dbms_output.put_line ( 'Concatenation: length = ' || dbms_lob.getlength(l_clob)||', time = '||to_char((l_t2 - l_t1)/100,'FM990D90')||' sec' );  
  
  -- test 2
  l_t1 := dbms_utility.get_time;
  dbms_lob.createtemporary(l_clob, true);
  for n in 1..100
  loop
    dbms_lob.writeappend(l_clob, length(to_char(rpad('1',32000))), to_char(rpad('1',32000)));
  end loop;
  l_t2 := dbms_utility.get_time;
  dbms_output.put_line ( 'WriteAppend  : length = ' || dbms_lob.getlength(l_clob)||', time = '||to_char((l_t2 - l_t1)/100,'FM990D90')||' sec' );
end;
/
...
Рейтинг: 0 / 0
10.2.0.5, ASMM, CLOB
    #39780672
Фотография Elic
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Деев И.
Код: plsql
1.
dbms_utility.get_time

Нельзя же быть таким дремучим…
Код: plsql
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
16.
BANNER
----------------------------------------------------------------
Oracle Database 10g Enterprise Edition Release 10.2.0.5.0 - 64bi
PL/SQL Release 10.2.0.5.0 - Production
CORE    10.2.0.5.0      Production
TNS for Linux: Version 10.2.0.5.0 - Production
NLSRTL Version 10.2.0.5.0 - Production

NAME_COL_PLUS_SHOW_PARAM                                                         TYPE        VALUE_COL_PLUS_SHOW_PARAM
-------------------------------------------------------------------------------- ----------- --------------------------
sga_target                                                                       big integer 1G

Concatenation: length = 32000000, time = +000000000 00:00:00.150262000
WriteAppend  : length = 32000000, time = +000000000 00:00:00.146868000

x86_64/Linux 2.4.xx

...
Рейтинг: 0 / 0
10.2.0.5, ASMM, CLOB
    #39780795
Деев И.
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Гость
Elic, спасибо!

При выключенном ASMM (sga_target = 0) на другой тестовой базе WriteAppend по сравнению с конкатенацией работает примерно в 30 раз быстрее. А при включенном - тормозит. И только что нашлась еще одна база 10.2.0.5 с включенным ASMM - картина повторяется.
(Трассировки есть, но не для всех случаев, поэтому полной картины еще нет).
...
Рейтинг: 0 / 0
10.2.0.5, ASMM, CLOB
    #39780816
Фотография Elic
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Деев И.WriteAppend по сравнению с конкатенацией работает примерно в 30 раз быстрее.Ты смотришь не туда или не так (IO). В 18c более ручной код наоборот заметно более медленно работает.
...
Рейтинг: 0 / 0
4 сообщений из 4, страница 1 из 1
Форумы / Oracle [игнор отключен] [закрыт для гостей] / 10.2.0.5, ASMM, CLOB
Целевая тема:
Создать новую тему:
Автор:
Закрыть
Цитировать
Найденые пользователи ...
Разблокировать пользователей ...
Читали форум (0):
Пользователи онлайн (0):
x
x
Закрыть


Просмотр
0 / 0
Close
Debug Console [Select Text]