Arhn - архитектура программирования

Sybase: как включение и выключение строк LOB влияет на блокировку

В нашей sybase ASE 15.7 db у нас есть таблица с 4 столбцами

uid int
id varchar 32
version varchar 32
xml text

Два индекса по uid и id соответственно; блокировка строк данных; ~130 строк данных

У нас также есть размер страницы 2k; xml длина мин. 1012/макс. 5176/avr 1837. На данный момент это вне строки LOB

Проблема в том, что иногда простая вставка занимает ~ 10-15 секунд, и я изо всех сил пытаюсь понять, почему.

  1. Кто-нибудь может дать какие-нибудь теории?
  2. Поможет ли внутрирядный LOB? наверное с размером 2000?
  3. В общем, как повлияет на блокировку блокировка в ряду/вне ряда?

Ответы:


1

Я бы сказал, что вам нужно протестировать его, что звучит очевидно, но это ключ к такому изменению, как это. Суть текстовых столбцов заключается в том, что у вас есть куча данных в конце таблицы, которая может быть фокусом для разногласий и блокировок.

Тем не менее, в вашем конкретном примере ваш средний размер строки довольно близок к максимальному размеру (1962 байта) для размера страницы вашего сервера Sybase. Вы не можете установить его на 2000 на сервере страниц 2k, потому что это больше, чем размер вашей страницы в байтах.

На самом деле вам нужно было бы установить его на 1894, что является вашим максимальным размером строки за вычетом других ваших столбцов, но это, вероятно, немного близко к максимуму, поэтому это зависит от того, насколько заполнены ваши столбцы идентификатора и версии.

Вы также не указываете, какой тип индексов используется, то есть кластеризованный или некластеризованный, потому что, если они некластеризованы, это все еще таблица кучи и может быть предметом конкуренции за последнюю цепочку страниц. Вы также не определяете количество строк в таблице или какую-либо другую информацию о том, почему ваши вставки слишком медленные, например, объем транзакций и т. д., поэтому рассмотрите возможность добавления этой информации в свое сообщение, например, планы запросов и т. д. или является ли идентификатор последовательным как точка доступа для вставок и так далее.

Внутрирядные LOB могут хорошо работать для правильных данных.

03.12.2018
Новые материалы

Коллекции публикаций по глубокому обучению
Последние пару месяцев я создавал коллекции последних академических публикаций по различным подполям глубокого обучения в моем блоге https://amundtveit.com - эта публикация дает обзор 25..

Представляем: Pepita
Фреймворк JavaScript с открытым исходным кодом Я знаю, что недостатка в фреймворках JavaScript нет. Но я просто не мог остановиться. Я хотел написать что-то сам, со своими собственными..

Советы по коду Laravel #2
1-) Найти // You can specify the columns you need // in when you use the find method on a model User::find(‘id’, [‘email’,’name’]); // You can increment or decrement // a field in..

Работа с временными рядами спутниковых изображений, часть 3 (аналитика данных)
Анализ временных рядов спутниковых изображений для данных наблюдений за большой Землей (arXiv) Автор: Рольф Симоэс , Жильберто Камара , Жильберто Кейрос , Фелипе Соуза , Педро Р. Андраде ,..

3 способа решить квадратное уравнение (3-й мой любимый) -
1. Методом факторизации — 2. Используя квадратичную формулу — 3. Заполнив квадрат — Давайте поймем это, решив это простое уравнение: Мы пытаемся сделать LHS,..

Создание VR-миров с A-Frame
Виртуальная реальность (и дополненная реальность) стали главными модными терминами в образовательных технологиях. С недорогими VR-гарнитурами, такими как Google Cardboard , и использованием..

Демистификация рекурсии
КОДЕКС Демистификация рекурсии Упрощенная концепция ошеломляющей О чем весь этот шум? Рекурсия, кажется, единственная тема, от которой у каждого начинающего студента-информатика..