Индексированные представления SQL :что произойдет, если данные изменились
Вопрос
Я не понимаю, что такое индексированное представление, но мне интересно, что именно происходит, когда данные в нижележащих таблицах были изменены?Удален ли весь кэш представления или просто изменены строки?
У меня очень сложный запрос к нескольким таблицам (+ 5), который используется для поиска доступности отелей (+ 100 тыс. записей), и индексированный просмотр IMHO может значительно повысить производительность.Но данные (несколько строк) часто меняются (комната была продана, свободные комнаты изменены в admin atc.), и если представление будет перестраиваться каждый раз, когда была изменена только одна строка, это будет бутылочным горлышком для моего приложения.
Или какие-нибудь идеи, как "кэшировать" очень коплексные запросы?
Спасибо.
Решение
Из документации technet:
В отличие от обычных индексов, одна строка вставка в любую из участвующих таблиц может привести к изменению нескольких строк в индексированном представлении.Это связано с тем, что одна строка может объединяться с несколькими строками другой таблицы.То же самое верно для обновлений и удалений.Следовательно, обслуживание индексированного представления может быть более дорогостоящим чем поддержание индекса в таблице .
Источник:
http://technet.microsoft.com/en-us/library/cc917715.aspx#XSLTsection124121120120
т. е.звучит так, как будто строки обновляются там, где это уместно, без необходимости обновлять / воссоздавать представление полностью.
Другие советы
Я предполагаю, что вы используете sql server.более 100 тысяч строк - это не так уж много.Если вы объединяете таблицы 5ish, я бы посоветовал вам убедиться, что в столбцах, к которым вы присоединяетесь, есть покрывающие индексы, прежде чем рассматривать возможность реализации индексированных представлений.Используйте анализатор запросов, чтобы найти горлышко бутылки непосредственно в вашем запросе.Если у вас возникли проблемы с производительностью на таких маленьких таблицах, там, вероятно, есть неприятные проверки таблиц.