Индексированные представления SQL :что произойдет, если данные изменились

StackOverflow https://stackoverflow.com/questions/2023319

  •  19-09-2019
  •  | 
  •  

Вопрос

Я не понимаю, что такое индексированное представление, но мне интересно, что именно происходит, когда данные в нижележащих таблицах были изменены?Удален ли весь кэш представления или просто изменены строки?

У меня очень сложный запрос к нескольким таблицам (+ 5), который используется для поиска доступности отелей (+ 100 тыс. записей), и индексированный просмотр IMHO может значительно повысить производительность.Но данные (несколько строк) часто меняются (комната была продана, свободные комнаты изменены в admin atc.), и если представление будет перестраиваться каждый раз, когда была изменена только одна строка, это будет бутылочным горлышком для моего приложения.

Или какие-нибудь идеи, как "кэшировать" очень коплексные запросы?

Спасибо.

Это было полезно?

Решение

Из документации technet:

В отличие от обычных индексов, одна строка вставка в любую из участвующих таблиц может привести к изменению нескольких строк в индексированном представлении.Это связано с тем, что одна строка может объединяться с несколькими строками другой таблицы.То же самое верно для обновлений и удалений.Следовательно, обслуживание индексированного представления может быть более дорогостоящим чем поддержание индекса в таблице .

Источник:

http://technet.microsoft.com/en-us/library/cc917715.aspx#XSLTsection124121120120

т. е.звучит так, как будто строки обновляются там, где это уместно, без необходимости обновлять / воссоздавать представление полностью.

Другие советы

Я предполагаю, что вы используете sql server.более 100 тысяч строк - это не так уж много.Если вы объединяете таблицы 5ish, я бы посоветовал вам убедиться, что в столбцах, к которым вы присоединяетесь, есть покрывающие индексы, прежде чем рассматривать возможность реализации индексированных представлений.Используйте анализатор запросов, чтобы найти горлышко бутылки непосредственно в вашем запросе.Если у вас возникли проблемы с производительностью на таких маленьких таблицах, там, вероятно, есть неприятные проверки таблиц.

Лицензировано под: CC-BY-SA с атрибуция
Не связан с StackOverflow
scroll top