이전 text/ntext/image 유형 열을 varchar/nvarchar/varbinary로 변환하는 SQL 데이터 업데이터를 작성하고 있습니다. 업데이터는 시스템이 부팅되어 이전 버전의 데이터베이스를 업데이트 할 때 트랜잭션 내에서 실행됩니다. 나는 SQL을 독자적으로 작동 시키려고했지만 소수의 컬럼이 전체 텍스트 인덱싱되었다. 즉 인덱스를 먼저 삭제하지 않고 유형을 변경할 수 없다는 것을 의미한다 :트랜잭션 내의 전체 텍스트 인덱싱 된 열 변경
ALTER FULLTEXT INDEX ON Table DROP (Column)
exec dbo.ConvertDataType 'Table', 'Column', 'nvarchar(max)'
ALTER FULLTEXT INDEX ON Table ADD (Column)
문제는 "ALTER FULLTEXT INDEX 문을 사용자 트랜잭션 내에서 사용할 수 없습니다."오류 때문에 첫 번째 행이 데이터 업데이터에서 작동하지 않습니다. 거래 내에서이를 가능하게 할 방법이 있습니까? 이 코드를 작동 시키거나 색인을 다른 유형으로 변경하는 방법이 있습니까?