Мне нужно программно включить READ COMMITTED SNAPSHOT в SQL Server. Как я могу это сделать?





ALTER DATABASE [dbname] SET READ_COMMITTED_SNAPSHOT ON WITH ROLLBACK AFTER 20 SECONDS
Согласно MSDN: указывает, когда нужно откатывать незавершенные транзакции, когда база данных переходит из одного состояния в другое. Если условие завершения опущено, оператор ALTER DATABASE ожидает неопределенное время, если в базе данных есть какая-либо блокировка.
Я рекомендую сначала переключиться в режим single-user. Это гарантирует, что вы единственная связь. В противном случае запрос может быть приостановлен.
От: http://msdn.microsoft.com/en-us/library/ms175095.aspx
When setting the READ_COMMITTED_SNAPSHOT option, only the connection executing the ALTER DATABASE command is allowed in the database. There must be no other open connection in the database until ALTER DATABASE is complete.
Итак, используйте этот SQL:
ALTER DATABASE <dbname> SET SINGLE_USER WITH ROLLBACK IMMEDIATE;
ALTER DATABASE <dbname> SET READ_COMMITTED_SNAPSHOT ON;
ALTER DATABASE <dbname> SET MULTI_USER;
Это была чертова палочка-выручалочка. Спасибо.
@ João - Для чего это? Это обязательно?
WITH ROLLBACK AFTER 20 SECONDS