WRITETEXT (Transact-SQL)
Обеспечивает интерактивное обновление существующего столбца типа text, ntext или image с минимальным ведением журнала. Инструкция WRITETEXT перезаписывает любые существующие данные в столбце, для которого применяется. Инструкцию WRITETEXT нельзя использовать для столбцов типа text, ntext или image в представлениях.
Важно! |
---|
В будущей версии Microsoft SQL Server этот компонент будет удален. Избегайте использования этого компонента в новых разработках и запланируйте изменение существующих приложений, в которых он применяется. Вместо этого пользуйтесь типами данных большого объема и предложением .WRITE инструкции UPDATE. |
Применимо для следующих объектов: SQL Server (начиная с SQL Server 2008 до текущей версии). |
Cинтаксические обозначения в Transact-SQL
Синтаксис
WRITETEXT [BULK]
{ table.column text_ptr }
[ WITH LOG ] { data }
Аргументы
BULK
Включает внешние средства для передачи потока двоичных данных. Поток должен быть передан средством на уровне протокола TDS. В отсутствие потока данных обработчик запросов не учитывает параметр BULK.Важно! Рекомендуется не использовать параметр BULK в приложениях с поддержкой SQL Server.Этот параметр может быть изменен или удален в следующих версиях SQL Server.
table . column
Имя обновляемой таблицы и столбца типа text, ntext или image. Имена таблиц и столбцов должны соответствовать правилам для идентификаторов. Указывать имена базы данных и владельца не обязательно.text_ptr
Значение, в котором хранится указатель на данные типа text, ntext или image. Аргумент text_ptr должен иметь тип binary(16). Для создания текстового указателя следует выполнить инструкцию INSERT или UPDATE с ненулевыми данными для столбца типа text, ntext или image.WITH LOG
Не учитывается SQL Server. Уровень ведения журнала определяется моделью восстановления, действующей для базы данных.data
Действительные данные text, ntext или image для сохранения. Аргумент data может быть литералом или параметром. Максимальная длина текста, который можно вставить интерактивно с помощью инструкции WRITETEXT — приблизительно 120 КБ для данных типа text, ntext и image.
Замечания
Инструкция WRITETEXT используется для замены данных типа text, ntext или image, а UPDATETEXT — для изменения данных типа text, ntext или image. Инструкция UPDATETEXT более гибкая, так как изменяет не весь столбец типа text, ntext или image, а только его часть.
Для достижения оптимальной производительности рекомендуется вставлять или обновлять данные типа text, ntext или image фрагментами, размер которых кратен 8 040 байт.
Если модель восстановления базы данных простая или с неполным протоколированием, операции над данными text, ntext и image, в которых используется инструкция WRITETEXT, выполняются с минимальным ведением журнала при вставке или добавлении новых данных.
Примечание
Если обновляются существующие значения, ведение журнала не сокращается до минимума.
Для правильного выполнения инструкции WRITETEXT столбец уже должен содержать действительный указатель на текст.
Если в строке таблицы не содержится текст, SQL Server экономит пространство, не выполняя инициализации столбцов text при добавлении явных или неявных значений NULL в столбцы text с помощью инструкции INSERT. Для этих значений NULL не может быть получен указатель на текст. Для инициализации столбцов text значением NULL следует использовать инструкцию UPDATE. Если в строке таблицы содержится текст, не нужно заполнять столбцы типа text значениями NULL и всегда можно получить указатель на текст.
Функция ODBC SQLPutData выполняется быстрее и занимает меньше динамической памяти, чем инструкция WRITETEXT. С помощью этой функции можно вставить до 2 гигабайт (ГБ) данных типа text, ntext или image.
В SQL Server указатели в строке на текст для данных text, ntext или image могут существовать, но быть неправильными. Дополнительные сведения об этом параметре text in row см. в документации по sp_tableoption (Transact-SQL). Дополнительные сведения о допустимости указателей текста см. в разделе sp_invalidate_textptr (Transact-SQL).
Разрешения
Требует разрешения UPDATE для указанной таблицы. Разрешение может передаваться, если передано разрешение UPDATE.
Примеры
В следующем примере указатель на текст вводится в локальную переменную @ptrval, а затем инструкция WRITETEXT помещает новую строку текста в строку, на которую указывает @ptrval.
Примечание
Для запуска данного примера необходимо установить образец базы данных pubs.
USE pubs;
GO
ALTER DATABASE pubs SET RECOVERY SIMPLE;
GO
DECLARE @ptrval binary(16);
SELECT @ptrval = TEXTPTR(pr_info)
FROM pub_info pr, publishers p
WHERE p.pub_id = pr.pub_id
AND p.pub_name = 'New Moon Books'
WRITETEXT pub_info.pr_info @ptrval 'New Moon Books (NMB) has just released another top ten publication. With the latest publication this makes NMB the hottest new publisher of the year!';
GO
ALTER DATABASE pubs SET RECOVERY SIMPLE;
GO