Вы можете включить флаг трассировки 7300, который может дать вам более подробное сообщение об ошибке
Сколько строк возвращает репрезентативный запрос? Насколько быстрым / надежным является сетевое соединение между двумя серверами?
Возможно, что для передачи большого набора данных требуется слишком много времени (сверх фактического времени запроса). Вы можете увеличить значение тайм-аута.
Вы можете попытаться изменить настройку тайм-аута следующим образом:
Установите время ожидания удаленного входа в систему на 300 секунд:
sp_configure 'remote login timeout', 300
go
reconfigure with override
go
Установите время ожидания удаленного запроса на 0 (бесконечное ожидание):
sp_configure 'remote query timeout', 0
go
reconfigure with override
go
Обновление : SQL Server 2012 SP1 иSELECT
более поздние версии : пользователи с разрешениями смогут получить доступ, DBCC SHOW_STATISTICS
что улучшит производительность только для чтения на связанных серверах. Ссылка: https://msdn.microsoft.com/en-us/library/ms174384(v=sql.110).aspx
Обновление : вы правы, говоря, что это не размер данных или скорость соединения. В моей туманной памяти прозвенел звонок, и я вспомнил, где видел его: медленно в приложении, быстро в SSMS? (Проблема со связанными серверами). Это не перехват параметров, а сама статистика отсутствует (из-за разрешений), из-за чего используется неверный план запроса:
Вы можете видеть, что оценки разные. Когда я работал как sysadmin, оценка составляла 1 строку, что является правильным числом, поскольку в Northwind нет заказов, где идентификатор заказа превышает 20000. Но когда я работал как обычный пользователь, оценка составляла 249 строк. Мы признаем это конкретное число как 30% от 830 заказов, или оценку операции неравенства, когда оптимизатор не располагает информацией. Ранее это происходило из-за неизвестного значения переменной, но в этом случае нет переменной, которая может быть неизвестна. Нет, сами статистические данные отсутствуют.
Пока запрос обращается только к таблицам на локальном сервере, оптимизатор всегда может получить доступ к статистике для всех таблиц в запросе; нет никаких дополнительных проверок разрешений. Но это не так с таблицами на связанном сервере. Когда SQL Server обращается к связанному серверу, не существует секретного протокола, который используется только для межсерверного взаимодействия. Нет, вместо этого SQL Server использует стандартный интерфейс OLE DB для связанных серверов, будь то другие экземпляры SQL Server, Oracle, текстовые файлы или ваш домашний источник данных, и подключается, как и любой другой пользователь. Точный способ получения статистики зависит от источника данных и соответствующего поставщика OLE DB. В этом случае поставщиком является собственный клиент SQL Server, который получает статистику в два этапа. (Вы можете увидеть это, запустив Profiler на удаленном сервере). Сначала провайдер запускает процедуру sp_table_statistics2_rowset, которая возвращает информацию о статистике столбцов, а также их количество элементов и их плотность. На втором этапе поставщик запускает команду DBCC SHOW_STATISTICS, которая возвращает полную статистику распространения. (Мы рассмотрим эту команду более подробно позже в этой статье.) Вот подвох: для запуска DBCC SHOW_STATISTICS вы должны быть членом роли сервера sysadmin или любой из ролей базы данных db_owner или db_ddladmin.
И именно поэтому я получил разные результаты. Когда я работал как sysadmin, я получил полную статистику распределения, которая показала, что нет строк с идентификатором заказа> 20000, и оценка составляла одну строку. (Напомним, что оптимизатор никогда не принимает нулевые строки из статистики.) Но при работе в качестве обычного пользователя DBCC SHOW_STATISTICS не удалось с ошибкой разрешения. Эта ошибка не распространялась, но вместо этого оптимизатор признал, что статистики не было, и использовал предположения по умолчанию. Так как он получил информацию о количестве элементов, он узнал, что в удаленной таблице 830 строк, откуда оценка в 249 строк.
Всякий раз, когда вы сталкиваетесь с проблемой производительности, когда запрос, который включает в себя доступ к связанному серверу, медленный в приложении, но он выполняется быстро, когда вы тестируете его из SSMS, вы должны всегда выяснять, могут ли быть причиной недостаточные разрешения для удаленной базы данных. (Имейте в виду, что доступ к связанному серверу может быть не явным в запросе, но может быть скрыт в представлении.) Если вы решите, что разрешения для удаленной базы данных являются проблемой, какие действия вы могли бы предпринять?
Вы можете добавить пользователей к роли db_ddladmin, но, поскольку это дает им право добавлять и удалять таблицы, это не рекомендуется.
По умолчанию, когда пользователи подключаются к удаленному серверу, они подключаются как они сами, но вы можете настроить сопоставление имени входа с помощью sp_addlinkedsrvlogin, чтобы пользователи сопоставлялись с учетной записью прокси, которая имеет членство в db_ddladmin. Обратите внимание, что эта учетная запись-посредник должна быть учетной записью SQL, поэтому это не вариант, если на удаленном сервере не включена проверка подлинности SQL. Это решение также несколько сомнительно с точки зрения безопасности, хотя оно лучше предыдущего предложения.
В некоторых случаях вы можете переписать запрос с помощью OPENQUERY для принудительной оценки на удаленном сервере. Это может быть особенно полезно, если запрос включает несколько удаленных таблиц. (Но это также может иметь неприятные последствия, поскольку оптимизатор теперь получает еще меньше статистической информации с удаленного сервера.)
Конечно, вы могли бы использовать всю совокупность советов и планов, чтобы получить план, который вы хотите.
Наконец, вы должны спросить себя, нужен ли этот доступ к связанному серверу. Может быть, базы данных могут быть на одном сервере? Могут ли данные быть скопированы? Какое-то другое решение?