1,问题描述:

在发布订阅时遇到发布服务器上表存在VERCHAR(MAX)在插入大字段数据时候报错:
消息7139,级别16,状态1,第1
要复制的LOB 数据的长度(937494)超出了配置的最大值65536
语句已终止。

2,解决办法

经过上网查资料原因是SQL SERVER设置了在复制中一个UPDATE,INSERT,WRITETEXTUPDATETEXT语句可以添加到复制列的最大数据量为65536Byte(64k),对于数据量大于64K的列并不采用自动截取的方式而是不允许插入或者更新来保证数据的完整性。解决方法如下:
使用 max text repl size 选项可以重新设定字段 text p_w_picpath 数据的大小(单位为字节)。它的缺省值是64K, 上限是2G.
此选项仅适用于事务复制。快照复制和合并复制将会忽略此选项。
该设置将立即生效,无需重新启动服务器。
方法一:
SQL Server Management Studio配置 max text repl size 选项:
1、在对象资源管理器中,右键单击服务器并选择“属性”。
2
、单击“高级”节点。
3
、在“杂项”下,将“最大文本复制大小”选项更改为所需的值。
方法二:
利用sp_configure修改max text repl size值;
  在查询分析器里运行:sp_configure 'max text repl size','2147483647'
此命令意思重新设置max text repl size值,为2G(即设置p_w_picpath字段存储容量为2G); 
说明:
命令格式:
sp_configure '配置选项的名称' '选项值'