Принцип high water mark что это значит
Деньги за деньги: как платить управляющему капиталом
Мы хорошо понимаем, что, когда портной шьет костюм, практически все зависит от него. Если работу делает профессионал, мы в итоге платим за конечный результат, в котором видно и качество работы, и сроки, и талант мастера.
В инвестициях все сложнее. Даже когда мы инвестируем в такие консервативные и предсказуемые акции, как McDonalds или Coca-Cola, нас ждет масса рисков, и никто, включая самого успешного управляющего портфелем или инвестиционного консультанта, не может точно сказать, сколько нам принесут эти вложения. Например, за последние 12 месяцев указанные бумаги выросли на 7,2% и 9% соответственно (здесь и дальше — данные на 17 сентября). А вот если посмотреть за два года, то картина получится неожиданная: акции McDonalds показали рост на 15,1%, а Coca-Cola — всего на 2,67%. Во время кризиса в марте 2020-го эти «спокойные» акции и вовсе потеряли около трети своей стоимости за несколько недель.
Какой же должна быть оплата труда «управленцев»? Посмотрим на сложившуюся практику и на новые тенденции, которые пробивают себе дорогу.
Как мы платим
Наконец, самый модный метод — специальные роботизированные системы (robo advisers), которые по заданному алгоритму управляют вашими деньгами. Так, американские роботы Betterment и Wealthfront берут всего 0,25% от стоимости капитала. Наверное, это и есть будущее, которое постепенно, пока в более простом и дорогом варианте, приходит и на российский рынок.
Сборы за успех
Если мы скажем, что результат инвестирования совсем не влияет на отношения инвестора и управляющего, это будет неправдой. Самый известный и раскрученный вариант представлен у хедж-фондов — их знаменитое 2% + 20%: 2% взимается от стоимости активов за управление, а 20% от полученной прибыли — это плата за успех (performance fee). Такая формула возникла во времена расцвета хедж-фондов и стала основой богатства многих управляющих. На практике есть различные ограничения на пресловутые 20%. Большинство хедж-фондов берут плату за результат только после того, как получат новую прибыль. Это правило именуется high-water mark и означает, что если в тот или иной год фонд несет убытки, ему следует в будущем сначала их возместить, и только потом брать плату за превышение своих пиковых значений.
Сейчас такие «жирные» сборы уже не вызывают восторга у частных инвесторов. Прежде всего потому, что хедж-фонды перестали быть синонимом успеха, к тому же на рынке появились более дешевые и зачастую более доходные инструменты. Возьмем, например, ETF — биржевые фонды с небольшими затратами, которые произвели своеобразную революцию на рынке инвестиций. Если в среднем американский паевой инвестиционный фонд взимает 1,42% годовых со своего клиента, то аналогичный ETF обходится ему всего в 0,53%.
Некоторые паевые фонды тоже берут плату за достигнутый результат. Обычно это премия за превышение того или иного бенчмарка, например, индексов S&P 500 или STOXX Europe 50. Однако большим спросом подобные фонды не пользуются.
В одной лодке
Что делать? На мой взгляд, наилучшим вариантом может быть использование смешанной модели, которая предполагает, что часть бизнеса управляющих работает с клиентами по традиционным правилам, а другая — по принципу «плати за результат». Можно перевести на подобный режим работы только самых ценных клиентов или тех, кто согласен на долгосрочное сотрудничество.
Можно использовать схему авансовых платежей с их обязательным возвратом. Скажем, клиент платит при подписании договора некую сумму, которая затем вычитается из суммы его оплаты за год. В каждом конкретном случае может быть спроектирована своя технология, которая учитывала бы специфику компании и те задачи, которая она ставит перед собой.
Плюсы и минусы
Конечно, при отрицательной доходности портфеля управляющая компания останется в убытке. Но это создает правильные стимулы. Материальное поощрение сотрудников компании попадает в прямую зависимость от доходности вложений, а не только от размера привлеченного капитала — значит, выгодно брать на работу талантливых сотрудников. Им есть чем платить за качество работы.
Со стороны частного инвестора тоже есть подводные камни. Есть опасность завышения уровня риска со стороны управляющей компании в погоне за крутыми результатами. Кстати, именно по этой причине паевым фондам в США запрещено взимать performance fee. Так что клиенту нужно очень внимательно читать договор, отслеживать состав своего портфеля и те операции, которые производятся с его активами. Открытость операций со стороны управляющего должна быть максимальной.
Когда рынок растет, инвестор не всегда обращает внимание на то, сколько он платит управляющему или советнику. Однако во время кризиса или в период затяжного восстановления рынка каждая копейка на счету. И здесь принцип «плати за результат» становится не только справедливым, но и самым желанным. Вполне вероятно, что после давно назревшей коррекции на фондовом рынке появится новое поколение управляющих, которое предложит миллионам инвесторов именно этот способ оплаты. Именно такие компании и станут лидерами на рынке инвестиционных услуг.
Мнение редакции может не совпадать с точкой зрения автора
Русские Блоги
Oracle HWM( High Water Mark)
Oracle HWM( High Water Mark)
1. Что такое HWM
Примечание. Сначала ознакомьтесь с физической и логической структурой Oracle в этой части.
Above the HWM:these blocks are unformatted and have never been used.
Когда я впервые начал создавать таблицу
При вставке данных
Когда вы удаляете данные, а затем вставляете данные
Когда недостаточно места
Почему на картинке показан низкий HWM? Поскольку мы находимся в ASSM (автоматическое управление пространством сегментов), когда данные вставляются в новый блок данных, блок данных не форматируется, но форматируется быстро при первом обращении к блоку данных. LowHWH должен идентифицировать отформатированный блок.
Смотрите официальный сайт для более подробного введения, и это будет многословно здесь.
2. Как понять HWM
Когда мы запрашиваем, мы сканируем наш блок хранимых данных, oracle сканирует блок данных ниже HWM. Когда мы используем таблицу данных, мы обнаружим проблему, то есть, когда мы впервые используем эту таблицу, мы чувствуем, что некоторые запросы выполняются очень быстро. Когда время использования велико, мы обнаружим, что эта таблица является запросом или какой операцией, Становится очень медленным, на самом деле, на этот раз это связано с этим HWM.
Если мы несколько раз обработали всю таблицу, то наш HWM станет очень высоким, и этот HWM не будет уменьшен сам по себе, и в это время пространство хранения в сегментации было выполнено много раз. Увеличьте операцию удаления, будет много места для мусора, в это время мы снова вставляем запись, Oracle последовательно сканирует все пространство памяти, находит пространство для мусора, которое может поместить всю запись, а затем заполняет эту запись, на этот раз сокращает вставленную запись. Эффективность, поэтому вы почувствуете, что операция станет очень медленной.
Точно так же, чтобы привести пример, когда мы вставляем 10 миллионов записей данных в новую таблицу, а затем используем операцию удаления для удаления этих записей, а затем снова выполняем операцию запроса, вы также обнаружите, что выбор выполняется очень медленно, хотя таблица Здесь нечего записывать, ведь HWM стал ключевым в это время.
3. Изменить HWM таблицы Oracle
3.1, восстановить таблицу
Скопируйте данные, которые необходимо сохранить, во временную таблицу, удалите исходную таблицу, а затем переименуйте временную таблицу в исходное имя таблицы.
3.2, свободный блок холостого хода
3.3, мобильное табличное пространство
Если табличное пространство не добавлено, по умолчанию это пространство
3,4 сжатия (рекомендуется)
Сегментная усадка делится на две стадии
1. Реорганизация данных: вставка, удаление и другие операции, насколько это возможно, чтобы расположить данные в передней части, в эту таблицу процессов добавит блокировку RX, блокировку только на строку, которую необходимо переместить. Из-за модификации rowid необходимо включить перемещение строк.
2. HWM настраивается для освобождения незанятых блоков данных. Этот процесс должен добавить X-блокировку к таблице, что приведет к блокировке оператора dml таблицы.
Интеллектуальная рекомендация
SpringBoot интегрирует Swagger2 для автоматического создания документов Api
Теперь, когда разделение на интерфейсную и внутреннюю части разработки стало тенденцией, в таком режиме разработки документы интерфейса особенно важны для интерфейсной части. Напомним, что в моей пред.
Предыдущие последствия движения 4 мая
Так называемый 4 мая движение в память о более чем сто лет назад, и 4 мая 1919 года группа колледжа парад. Прочитав эту фразу, я чувствую, что сила воли новорожденной всегда принадлежит к новому покол.
Виртуальная машина Linux быстро создает полный процесс RabbitMQ (версия для распаковки) (простой и понятный, а не про тест может написать так много)
Отказ от ответственности: я создаю среду виртуальной машины Linux в системе Windows 10. Все установочные пакеты загружаются, распаковываются и устанавливаются вручную. Любой, кто любит устанавливать о.
Управляющий трейдер
Профессионального трейдера в управлении у которого помимо его собственных средств, находятся деньги других инвесторов, называют управляющим трейдером. Основная задача управляющего трейдера состоит в том, чтобы получать стабильную прибыль, превышающую средний банковский процент по вкладам при минимальном риске привлеченными к управлению денежными средствами.
Вы наверняка не раз слышали о таком понятии как ПАММ-счета. Это счета на FOREX где управляющим трейдером может стать каждый желающий. Но одно дело стать управляющим трейдером, а другое дело привлечь капитал клиентов. Для привлечения клиентов управляющий трейдер должен показать стабильные результаты торговли с использованием собственных денежных средств. Торговый счет управляющего трейдера должен быть открыт к просмотру для потенциальных инвесторов, чтобы те в свою очередь могли оценить его и принять решение о сотрудничестве. См. также: «Как стать управляющим трейдером на FOREX«
К сожалению, само понятие ПАММ-счёт уже успело набить оскомину инвесторам пытающимся вкладывать деньги на просторах всемирной сети интернет. Дело в том, что подавляющее большинство управляющих ПАММ-счетами это непрофессиональные трейдеры. Такая ситуация складывается благодаря доступности этого вида деятельности (стать ПАММ-управляющим сегодня может стать любой желающий с депозитом от 100$).
Многие ПАММ-счета ведутся, что называется, наобум. Те из них, которые в итоге показали прибыль (а раз в году, как говориться, и палка стреляет) могут даже привлечь к себе инвесторов. Многие ПАММ-управляющие ведут автоматическую торговлю с использованием советников (торговых роботов) алгоритм которых основан на методе Мартингейла.
Для справки: Метод Мартингейла основан на повышении ставок после каждого проигрыша до тех пор, пока не будет получен выигрыш. Теоретически этот метод является беспроигрышным, однако на практике его применение зачастую приводит к полному сливу депозита. Это происходит ввиду того, что из-за серии проигрышей ставка, возрастающая в геометрической прогрессии, может превысить размер торгового счёта трейдера.
Однако понятие управляющий трейдер, конечно же, не ограничивается одними только ПАММ-счетами на Форекс. Трейдеры торгующие на бирже, также могут управлять средствами инвесторов, заключившими с ними соответствующий договор. Другое дело, что трейдеру торгующему вне системы ПАММ-счетов, гораздо сложнее получить статус управляющего. В данном случае ему необходимо проявить действительно незаурядные способности.
Как рассчитывается вознаграждение управляющего трейдера
В мировой практике есть два основных способа вознаграждения трейдеров управляющих инвестициями своих клиентов:
Каждый из этих способов имеет свои достоинства и недостатки. На первый взгляд кажется, что наиболее справедливым и выгодным для инвестора является способ оплаты услуг по управлению в виде процента от заработанной прибыли. Однако на деле всё не так просто, как может показаться на первый взгляд.
При оплате за успех (Success fee) управляющий трейдер мотивирован на то, что бы получить прибыль, что называется, любой ценой. Это может толкать его к неоправданным рискам, ведь при проигрыше он, по сути, ничего не теряет, а в случае выигрыша – может рассчитывать на гарантированное вознаграждение.
Вот вам простой пример. Допустим по договору, расчёт должен производиться раз в квартал, по результатам работы за эти три месяца. В первый квартал трейдер получил прибыль в размере 6%, во втором квартале – убыток в 15%, в третьем – прибыль в 2%, в четвёртом – прибыль в 4%. Таким образом, по результатам работы за год, управляющий трейдер, получил свой процент прибыли от 12% капитала инвестора. А сам инвестор при этом остался в убытке размером в 3% (плюс та сумма, которую он выплатил в качестве вознаграждения).
Впрочем, есть возможность использовать метод расчёта вознаграждения по принципу Success fee, но с поправкой на High Watermark (в дословном переводе с английского – «высокий водяной знак»). Суть принципа High Watermark состоит в том, что расчёт вознаграждения управляющего ведётся не по результатам квартала, а по максимумам за каждый отчётный квартал.
Поясню на примере. Если трейдер получил в управление 100000 рублей, а затем:
То в результате, по результатам работы за первый квартал, управляющий не получит ничего (был убыток). А по результатам работы за второй квартал, он получит вознаграждение, но это будет процент не от суммы в 5000 рублей (102000-97000=5000), как это было бы в случае применения простого принципа Success fee, а процент от суммы в 2000 рублей (102000-100000=2000).
Кроме этого, существует ещё один способ позволяющий «заставить» трейдера преследовать в первую очередь интересы клиента, а не свои собственные. Этот способ заключается в том, что определяются некие ключевые показатели инвестиционного портфеля, которых трейдер должен, в обязательном порядке, придерживаться. Отклонение одного или нескольких показателей от заданного в договоре значения, будет чревато тем, что трейдер попросту лишится своего вознаграждения (представляющего, обычно, процент от торгуемого капитала).
Среди этих задаваемых показателей могут быть, например, такие как:
Но этот способ доступен лишь тем инвесторам, в распоряжении которых имеется действительно значительный торговый капитал (порядка 1 миллиона американских долларов). В иных случаях, обычно ни трейдеры, ни управляющие компании не идут на такие условия торговли.
Русские Блоги
Описание Oracle High Water Mark (HWM: High Water Mark)
1. Подготовительные знания: логическое управление хранилищем ORACLE.
ORACLE разделен на 4 уровня логического хранения: табличное пространство, сегмент, область и блок.
1.2 Область: Состоит из ряда смежных блоков.Это также основная единица распределения пространства ORACLE.Например, когда мы создаем таблицу, Дейв, сначала ORACLE выделит для этой таблицы область пространства. Постоянно ВСТАВЛЯЙТЕ данные Дейву. Когда исходная область не может вместить вставленные данные, ORACLE расширяется в единицах областей, что означает, сколько областей выделено Дейву, а не количество блоков.
1.3 Сегмент: он состоит из серии областей. В общем, когда создается объект (таблица, индекс), ему назначается сегмент. Таким образом, в некотором смысле сегмент является конкретным Данные. Например, CREATE TABLE, Дейв, этот сегмент является сегментом данных, и CREATE INDEX ON Dave (NAME), ORACLE также выделит сегмент этому индексу, но это сегмент индекса. Информация о сегменте запроса может быть представлена через словарь данных: SELECT * FROM USER_SEGMENTS получить.
1.4 Табличное пространство: содержит сегменты, регионы и блоки. Данные табличного пространства физически хранятся в файле данных, в котором они расположены. База данных должна иметь хотя бы одно табличное пространство.
Табличное пространство (tableSpace) сегмент (сегмент) экстент (экстент) блок (блок) связь
Когда мы создавали таблицу, даже если я не вставлял ни одной строки записей, ORACLE по-прежнему выделил ей 8 блоков. Конечно, это связано с параметрами INITIAL и MINEXTENTS оператора создания таблицы. Например:
Описание параметра создания таблицы Oracle
2.1 Официальное описание веб-сайта выглядит следующим образом
To manage space, Oracle Database tracks the state of blocks in the segment.The high water mark (HWM) is the point in a segment beyond which data blocks are unformatted and have never been used.
MSSM uses free lists to manage segment space.At table creation, no blocks in the segment are formatted.When a session first inserts rows into the table, the database searches the free list for usable blocks.If the database finds no usable blocks, then it preformats a group of blocks, places them on the free list, and begins inserting data into the blocks.In MSSM,a full table scan reads all blocks below the HWM.
ASSM does not use free lists and so must manage space differently.When a session first inserts data into a table, the database formats a single bitmap block instead of preformatting a group of blocks as in MSSM. The bitmap tracks the state of blocks in the segment, taking the place of the free list. The database uses the bitmap to find free blocks and then formats each block before filling it with data.ASSM spread out inserts among blocks to avoid concurrency issues.
Oracle автоматическое управление пространством сегментов (ASSM: автоматическое управление пространством сегментов)
Every data block in an ASSM segment is in one of the following states:
These blocks are unformatted and have never been used.
These blocks are in one of the following states:
(1)Allocated, but currently unformatted and unused
(2)Formatted and contain data
(3)Formatted and empty because the data was deleted
Figure 12-23depicts an ASSM segment as ahorizontal series of blocks. At table creation, the HWM is at the beginning of the segment on the left. Because no data has been inserted yet, all blocks in the segment are unformatted and never used.
Figure 12-23 HWM at Table Creation
Suppose that a transaction inserts rows into the segment. The database must allocate a group of blocks to hold the rows.The allocated blocks fall below the HWM.The database formats a bitmap block in this group to hold the metadata, but does not preformat the remaining blocks in the group.
InFigure 12-24, the blocks below the HWM are allocated, whereas blocks above the HWM are neither allocated or formatted. As inserts occur, the database can write to any block with available space.The low high water mark (low HWM) marks the point below which all blocks are known to be formatted because they either contain data or formerly contained data.
Figure 12-24 HWM and Low HWM
InFigure 12-25, the database chooses a block between the HWM and low HWM and writes to it. The database could have just as easily chosen any other block between the HWM and low HWM, or any block below the low HWM that had available space. InFigure 12-25, the blocks to either side of the newly filled block are unformatted.
Figure 12-25 HWM and Low HWM
The low HWM is important in afull table scan.Because blocks below the HWM are formatted only when used, some blocks could be unformatted, as inFigure 12-25. For this reason,the database reads the bitmap block to obtain the location of the low HWM. The database reads all blocks up to the low HWM because they are known to be formatted, and then carefully reads only the formatted blocks between the low HWM and the HWM.
Assume that a new transaction inserts rows into the table, but the bitmap indicates that insufficient free space exists under the HWM. InFigure 12-26, the database advances the HWM to the right, allocating a new group of unformatted blocks.
Figure 12-26 Advancing HWM and Low HWM
When the blocks between the HWM and low HWM are full, the HWM advances to the right and the low HWM advances to the location of the old HWM. As the database inserts data over time, the HWM continues to advance to the right, with the low HWM always trailing behind it.Unless you manually rebuild, truncate, or shrink the object, the HWM never retreats.
Описание блока данных Oracle
2.2 Высшая точка HWM в сегменте таблиц Oracle
Оператор Select сканирует данные в таблице, но сколько блоков хранилища сканируется? Это не означает, что Oracle сканирует такие большие блоки данных, но Oracle сканирует данные ниже максимальной отметки. блок данных. Теперь представьте, что если это была недавно созданная пустая таблица и вы выполнили операцию Select, то, поскольку максимальная отметка HWM находится в самой нижней позиции 0, нет блока данных для сканирования, и время сканирования будет чрезвычайно коротким. И если на этот раз вы сначала вставите десять миллионов фрагментов данных, а затем используете оператор delete для удаления этих десяти миллионов фрагментов данных. Поскольку было вставлено 10 миллионов фрагментов данных, сейчас самая высокая точка. Когда десять миллионов частей данных удаляются позже, поскольку оператор удаления не влияет на максимальную отметку, максимальная отметка остается здесь для десяти миллионов частей данных. В этот раз используйте оператор select для повторного сканирования. Хотя в данный момент в таблице нет данных, поскольку сканирование основано на максимальной отметке, пространство для хранения 10 миллионов фрагментов данных необходимо сканировать один раз, то есть на этот раз Время, необходимое для сканирования, равно времени, необходимому для сканирования 10 миллионов единиц данных. Так что иногда люди всегда говорят, почему в моей таблице не так мало данных, но это все еще так медленно.
При ручном управлении пространством сегмента (ручное управление пространством сегмента) в сегменте есть только один HWM, но в автоматическом управлении пространством сегмента (Automatic Segment Space Management), добавленном в Oracle 9i Release 1, существует еще одна концепция низкого HWM. Почему низкий уровень HWM с HWM? Это вызвано особенностями автоматического управления пространством сегментов. В средствах управления пространством сегмента, когда данные вставляются, если они вставляются в новый блок данных, блок данных будет автоматически отформатирован и будет ожидать доступа к данным. При автоматическом управлении пространством сегментов после вставки данных в новый блок данных блок данных не форматируется, но блок данных форматируется при первом доступе к блоку данных. Итак, нам нужен еще один водяной знак, чтобы отметить блоки, которые были отформатированы. Этот водяной знак называется низким HWM. Вообще говоря, низкий HWM определенно ниже или равен HWM.
2.3. Исправьте максимальную отметку в таблице ORACLE.
В ORACLE выполнение операции удаления для таблицы не приведет к понижению верхней отметки таблицы. При полном сканировании таблицы всегда будут считываться все блоки на экстенте ниже максимальной отметки. Если отметка максимального уровня не будет снижена после выполнения операции удаления, производительность оператора запроса будет низкой. Такие операции, как восстановление, усечение, сжатие и перемещение, снизят высокий уровень воды.
2.3.1 Выполнить команду восстановления таблицы alter table table_name move;
Когда вы создаете объект, такой как таблица, независимо от того, вставляете вы данные или нет, он будет занимать несколько блоков, и ORACLE также выделит для него необходимое пространство. Точно так же после освобождения свободного пространства с помощью ALTER TABLE MOVE некоторое пространство все еще зарезервировано для Этот стол.
2.3.2 Выполнить изменение таблицы имя_таблицы сжимать пространство;
Эта команда является новой функцией Oracle 10g, и перед выполнением этой команды необходимо разрешить перемещение строк. Alter table имя_таблицы включить перемещение строк;
2.3.3 Перестроить таблицу
Скопируйте данные, которые нужно сохранить, во временную таблицу t, удалите исходную таблицу, а затем переименуйте временную таблицу t как исходную.
2.3.4 Импорт и экспорт с логикой: Emp / Imp
2.3.5. Altertable table_name deallocate unused
DEALLOCATE UNUSED освобождает неиспользуемое пространство над HWM, но не освобождает свободное пространство под HWM и не перемещает положение HWM.
2.3.6 Рекомендуется использовать усечение.
2.3.7 Некоторые примечания
(1) Если это INEXTENT, вы можете освободить alter table tablename, чтобы освободить все неиспользуемое пространство над HWM.
(2) Если MINEXTENT> HWM, освободите место над MINEXTENTS. Если вы хотите освободить пространство над HWM, используйте KEEP 0.
SQL>alter table tablesname deallocate unused keep 0;
(3) Команда усечения таблицы отбрасывания (значение по умолчанию) может полностью освободить пространство над MINEXTENT (вернуться в операционную систему) и сбросить HWM.
(4) Если вы хотите переместить только HWM и не хотите, чтобы таблица была заблокирована в течение длительного времени, вы можете использовать хранилище повторного использования усеченной таблицы, чтобы сбросить только HWM.
(5) ALTER TABLE MOVE переместит HWM, но при MOVE требуется двойное табличное пространство, и если в таблице есть индекс, индекс необходимо восстановить.
(6) Таблица DELETE не сбрасывает HWM и не освобождает свободное пространство (то есть пространство, освобожденное с помощью DELETE, может использоваться только самим объектом для будущих INSERT / UPDATE и не может использоваться другими объектами)
(1) Вы можете использовать команду alter table test_tab shrink space для перемещения hwm в оперативный режим,
(2) Если вы хотите одновременно сжать индекс таблицы, вы можете опубликовать: alter table test_tab shrink space cascade
2.4 Возможности HWM
2.4.1 ORACLE использует HWM для разграничения используемых блоков и неиспользуемых блоков в сегменте.
Например, когда мы создаем таблицу, ORACLE выделяет сегмент для этого объекта. В этом сегменте, даже если мы не вставляем никаких записей, выделяется по крайней мере одна область, первая область является первой. Блок называется заголовком сегмента (SEGMENT HEADE), некоторая информация хранится в заголовке сегмента, а информация HWM в базе хранится здесь.
В настоящее время, поскольку первый блок первой области используется для хранения некоторой информации заголовка сегмента, хотя фактические записи не хранятся, он считается использованным. В настоящее время HWM находится во втором блоке. Когда мы продолжаем вставлять данные После прибытия в таблицу первый блок больше не может соответствовать вновь вставленным данным. В настоящее время ORACLE использует блок выше верхней отметки для хранения новых данных, и в то же время сам HWM также перемещается вверх. То есть, когда мы продолжаем При вставке данных HWM будет продолжать двигаться вверх, так что блоки под HWM указывают на используемые блоки, а блоки над HWM указывают на блоки, которые были выделены, но никогда не использовались.
2.4.2 Когда HWM вставляет данные, он будет перемещаться вверх, когда существующего пространства недостаточно, и оно расширяется, но не будет перемещаться вниз при удалении данных.
ORACLE не освобождает пространство для использования другими объектами по простой причине: пространство зарезервировано для вновь вставленных строк и для адаптации к росту существующих строк. Самая высокая занимаемая площадь называется самой высокой оценкой использования (HWM),
2.4.3 Информация HWM хранится в заголовке сегмента.
Информация о самом HWM хранится в заголовке сегмента. Когда пространство сегмента управляется вручную, ORACLE управляет распределением пространства внутри сегмента через FREELIST (односвязный список). Когда пространство сегмента управляется автоматически (ASSM), ORACLE С помощью BITMAP можно управлять распределением пространства в сегменте.
2.4.4 Полное сканирование таблицы ORACLE предназначено для чтения всех блоков ниже верхней отметки (HWM).
Таким образом, возникает проблема: когда пользователь выполняет полное сканирование таблицы, ORACLE всегда должен сканировать от сегмента до HWM, даже если он ничего не находит. Эта задача продлевает время полного сканирования таблицы.
Например, путем прямой загрузки и вставки (с помощью APPEND для запроса вставки) или с помощью блока данных прямого пути SQL * LOADER, непосредственно размещенного на HWM. Пространство под ним потрачено впустую.
3. Сопутствующие тесты
1) Создайте тестовую таблицу
SQL> create table tt (id number);
Таблица на данный момент не анализируется, это исходные данные, то есть 8 блоков данных.
SQL>SELECT segment_name,segment_type,blocks FROM dba_segmentsWHERE segment_name=’TT’;
SQL> SELECT table_name,num_rows,blocks,empty_blocks FROM user_tablesWHERE table_name=’TT’;
2) Вставьте тестовые данные в таблицу
4for i in 1..10000 loop
5insert into tt values(i);
PL/SQL procedure successfully completed.
3) Просмотрите информацию таблицы в то время
SQL> SELECT table_name,num_rows,blocks,empty_blocks FROM user_tablesWHERE table_name=’TT’;
SQL>SELECT segment_name,segment_type,blocks FROM dba_segmentsWHERE segment_name=’TT’;
На данный момент количество баз данных, занятых таблицей TT, составляет уже 24. Но информация, отображаемая user_tables, по-прежнему пуста. Потому что нет статистического анализа.
4) Собираем статистику
SQL> exec DBMS_STATS.GATHER_TABLE_STATS(‘SYS’,’TT’);
PL/SQL procedure successfully completed.
SQL>SELECT segment_name,segment_type,blocks FROM dba_segmentsWHERE segment_name=’TT’;
SQL> SELECT table_name,num_rows,blocks,empty_blocks FROM user_tablesWHERE table_name=’TT’;
На данный момент user_tables уже имеет данные, показывающие, что используются 20 блоков данных. Но empty_blocks по-прежнему пуст. Здесь стоит обратить внимание. В этом поле будут данные только после использования анализа для сбора статистики.
5) Используйте анализ для сбора статистики
SQL> ANALYZE TABLE TT COMPUTE STATISTICS;
SQL> SELECT table_name,num_rows,blocks,empty_blocks FROM user_tablesWHERE table_name=’TT’;
— Здесь отображаются 3 пустые базы данных. Примечание: 20 + 3 = 23. На единицу занято меньше 24 блоков данных. Поскольку есть блок базы данных, он зарезервирован как заголовок сегмента.
SQL>SELECT segment_name,segment_type,blocks FROM dba_segmentsWHERE segment_name=’TT’;
6) Удалить данные без снижения высокого уровня воды
SQL> delete from tt;
10000 rows deleted.
SQL>SELECT segment_name,segment_type,blocks FROM dba_segmentsWHERE segment_name=’TT’;
SQL> SELECT table_name,num_rows,blocks,empty_blocks FROM user_tablesWHERE table_name=’TT’;
SQL> analyze table tt compute statistics;
SQL> SELECT table_name,num_rows,blocks,empty_blocks FROM user_tablesWHERE table_name=’TT’;
SQL>SELECT segment_name,segment_type,blocks FROM dba_segmentsWHERE segment_name=’TT’;
7) усеченная таблица, может снизить высокий уровень воды
SQL> truncate table tt;
SQL>SELECT segment_name,segment_type,blocks FROM dba_segmentsWHERE segment_name=’TT’;
SQL> SELECT table_name,num_rows,blocks,empty_blocks FROM user_tablesWHERE table_name=’TT’;
—Информация сегмента не изменилась, соберите статистику, чтобы увидеть
SQL> exec dbms_stats.gather_table_stats(‘SYS’,’TT’);
PL/SQL procedure successfully completed.
SQL> SELECT table_name,num_rows,blocks,empty_blocks FROM user_tablesWHERE table_name=’TT’;
SQL>SELECT segment_name,segment_type,blocks FROM dba_segmentsWHERE segment_name=’TT’;
—Информация в разделе была изменена, но раздел empty_blocks не изменился.Этот раздел можно изменить только с помощью анализа.
SQL> analyze table tt compute statistics;
SQL> SELECT table_name,num_rows,blocks,empty_blocks FROM user_tablesWHERE table_name=’TT’;
SQL>SELECT segment_name,segment_type,blocks FROM dba_segmentsWHERE segment_name=’TT’;
4. Разница между изменением перемещения стола и сжатием
В следующих двух блогах есть инструкции:
Разница между изменением перемещения стола и сжатием пространства
Описание на MOS, ID: 577375.1:
После 10g дефрагментация устраняет новую функцию сокращения пространства миграции строк
SQL>alter table
compact: этот параметр можно использовать при относительно большой нагрузке на систему без уменьшения HWM. Если нагрузка на систему низкая, используйте напрямую alter table table_name shrink space, чтобы сделать это за один шаг
cascade: этот параметр автоматически представляет собой каскадный индекс при сжатии таблицы, что эквивалентно rebulid index.
Следующий SQL основан на обычных таблицах
Сжатие должно включать функцию переноса строк.
alter table table_name enable row movement ;
Сохранение HWM равносильно сжатию данных в блоке
alter table table_name shrink space compact;
Стол отвода и нижний HWM
alter table table_name shrink space;
Сжать таблицы и связанные индексы, уменьшить HWM
alter table table_name shrink space cascade;
Индекс втягивания и нижний HWM
alter index index_name shrink space
Хотя усадку можно использовать в 10 г, есть некоторые ограничения:
2). Таблицы с индексами на основе функций или индексами соединения растровых изображений не поддерживаются.
3) Таблицы сопоставления или таблицы с индексированием не поддерживаются.
4). Сжатая таблица не поддерживается
Используйте desc table_name, чтобы проверить, есть ли в таблице LOB-поле. Если в таблице нет LOB-поля, напрямую измените перемещение таблицы; затем перестройте индекс
Если таблица содержит LOB-поля, такие как следующий SQL:
SQL>alter table owner.table_name move tablespace tablespace_name lob (lob_column) store as lobsegment tablespace tablespace_name;
Вы также можете переместить лобовой объект отдельно, но индекс в таблице также будет недействительным. Поэтому в конце операции вам необходимо перестроить индекс.
SQL>alter table owner.table_name move lob(lob_column) store as lobsegment tablespace tablespace_name ;
Сначала используйте следующий SQL, чтобы узнать, какие индексы находятся в таблице:
Для обычных индексов прямое восстановление параллельной сетевой логики,
Для многораздельных индексов каждый раздел необходимо перестраивать отдельно,
Для составных индексов разделов каждый подраздел необходимо перестраивать отдельно.
Move уменьшает HWM за счет перемещения данных, поэтому требуется больше места на диске. Сжатие приведет к большему числу отмен и повторов посредством удаления и вставки.
Пространство сжатия сжимается до минимального значения хранилища данных, а перемещение измененной таблицы (без параметров) сжимается до начального указанного значения, или вы можете использовать хранилище тестового перемещения измененной таблицы (начальное 500 КБ), чтобы указать размер сжатия, что может достичь эффекта пространства сжатия.
Короче говоря, использование Move будет более эффективным, но приведет к сбою индекса. Сжатие приведет к отмене и повторению, и скорость будет относительно низкой.