Java自学者论坛

 找回密码
 立即注册

手机号码,快捷登录

恭喜Java自学者论坛(https://www.javazxz.com)已经为数万Java学习者服务超过8年了!积累会员资料超过10000G+
成为本站VIP会员,下载本站10000G+会员资源,会员资料板块,购买链接:点击进入购买VIP会员

JAVA高级面试进阶训练营视频教程

Java架构师系统进阶VIP课程

分布式高可用全栈开发微服务教程Go语言视频零基础入门到精通Java架构师3期(课件+源码)
Java开发全终端实战租房项目视频教程SpringBoot2.X入门到高级使用教程大数据培训第六期全套视频教程深度学习(CNN RNN GAN)算法原理Java亿级流量电商系统视频教程
互联网架构师视频教程年薪50万Spark2.0从入门到精通年薪50万!人工智能学习路线教程年薪50万大数据入门到精通学习路线年薪50万机器学习入门到精通教程
仿小米商城类app和小程序视频教程深度学习数据分析基础到实战最新黑马javaEE2.1就业课程从 0到JVM实战高手教程MySQL入门到精通教程
查看: 506|回复: 0

Sqlserver 报错“参数数据类型 ntext/text 对于 replace 函数的参数 1 无效”的解决方案及原理分析扩展

[复制链接]
  • TA的每日心情
    奋斗
    2024-11-24 15:47
  • 签到天数: 804 天

    [LV.10]以坛为家III

    2053

    主题

    2111

    帖子

    72万

    积分

    管理员

    Rank: 9Rank: 9Rank: 9

    积分
    726782
    发表于 2021-5-6 14:01:06 | 显示全部楼层 |阅读模式

    原因:在数据查询中replace函数无法对表table中text/ntext类型的字段colname进行了字符串操作。

    解决方法:将text当作varchar(实际内容长度低于8000字节时)或把ntext当作nvarchar(实际内容长度低于4000字节时)。

    但是当text字段内容长度超过8000或ntext字段内容长度超过4000字节时多出的字节会被截断而忽略掉。

    这时我们可以使用max类型来解决这个问题。

    原报错代码:

    update tablename set colname=replace(colname,'oldtext','newtext'); 

    修改后可执行代码:

    update tablename set colname=replace(Cast(colname as varchar(8000)),'oldtext','newtext');
    update tablename set colname=replace(Cast(colname as nvarchar(4000)),'oldtext','newtext');

    附:max类型的介绍 
    varchar(max)、nvarchar(max) 和 varbinary(max) 统称为大值数据类型。可以使用大值数据类型来存储最大为 2^31-1 个字节的数据。 
    max 说明符是在Microsoft SQL Server 2005 中引入的。此说明符增强了 varchar、nvarchar 和 varbinary 数据类型的存储能力。

    当 sp_tableoption 存储过程的 ‘large value types out of row’ 选项设置为 OFF 时,大值类型的行内存储限制为 8000 个字节。当此选项设置为 ON 时,只在行内存储 16 字节的根。可查找参考关于sp_tableoption (Transact-SQL)的内容。

    大值数据类型在行为上和与之对应的较小的数据类型 varchar、nvarchar 和 varbinary 相似。这种相似使 SQL Server 能够更高效地存储和检索大型字符、Unicode 和二进制数据。

    因为有了大值数据类型,使一些使用 SQL Server 的方式是使用早期版本的 SQL Server 中的 text、ntext 和 image 数据类型所没有的。例如,在 SQL Server 2005 中,您可以定义能存储大量数据(最多可达 2^31 字节的字符、整数和 Unicode 数据)的变量。可查找参考关于Transact-SQL 变量的内容。 
    Transact-SQL 变量示例: 
    DECLARE @MyURL nvarchar(2000); 
    set @MyURL=’https://www.cnblogs.com/NeilShieh/‘;

    下面是大值数据类型和 SQL Server 早期版本(如SQL 2000)中与之对应的数据类型之间的关系。

    大值数据类型       早期版本中的 LOB 
    varchar(max)     text* 
    nvarchar(max)     ntext* 
    varbinary(max)       image

    SQL Server 6.5 版本的客户端不支持 ntext 数据类型,因此无法识别 nvarchar(max)。

    在SQL 2005中请使用 varchar(max)、nvarchar(max) 和 varbinary(max) 数据类型,而不要使用 text、ntext 和 image 数据类型。

    大值数据类型在行为上和与之对应的较小的数据类型 varchar(n)、nvarchar(n) 和 varbinary(n) 相同。下面介绍大值数据类型在某些特定情形下的使用:

    游标 
    由于可以定义大值数据类型变量,便可以将 FETCH 返回的大值数据类型列中的数据赋给本地变量。可查找参考关于 FETCH (Transact-SQL)的内容。 
    使用大值数据类型不影响游标的强制实施游标类型转换用法。

    成块更新 
    UPDATE 语句现在支持 .WRITE( ) 子句对基础大值数据列进行部分更新。这类似于 SQL Server 早期版本中所支持的对 text、ntext、image 数据类型的文本指针操作、WRITETEXT 和 UPDATETEX。可查找参考关于UPDATE (Transact-SQL)的内容。

    触发器 
    支持对插入的和删除的表中的大值数据类型列引用上使用 AFTER 触发器。可查找参考关于CREATE TRIGGER (Transact-SQL)的内容。

    字符串函数 
    内置的可操作字符和二进制数据的字符串函数有所增强,可支持大值数据类型的参数。这些函数包括: 
    COL_LENGTH 
    CHARINDEX 
    PATINDEX 
    LEN 
    DATALENGTH 
    SUBSTRING

    哎...今天够累的,签到来了1...
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    QQ|手机版|小黑屋|Java自学者论坛 ( 声明:本站文章及资料整理自互联网,用于Java自学者交流学习使用,对资料版权不负任何法律责任,若有侵权请及时联系客服屏蔽删除 )

    GMT+8, 2025-1-23 00:50 , Processed in 0.125353 second(s), 29 queries .

    Powered by Discuz! X3.4

    Copyright © 2001-2021, Tencent Cloud.

    快速回复 返回顶部 返回列表