数据类型nText和varchar在运算符equals不兼容的问题解决方案

 1.直接改数据库字段类型,这种方式治标不治本,不推荐使用!因为既然使用了nText和Text类型,说明该字段的数据长度比较大,不好预估,当然SQLserver2005以上 的nvarchar(max) 可以存放2G的内容,足够用来替换nText类型了。

 2.使用T-SQL函数 cast 或者 convert 转换nText字段的数据类型:

 (1)更新语句:

    cast函数: update tb_test set cast([A] as nvarchar(max))='xxx'

    convert函数:update tb_test set convert(nvarchar(max),[A])='xxx'

 (2)插入语句:

       cast函数:     insert into tb_test([A]) where cast(’xxx’ as nvarchar(max)) 

    convert函数:insert into tb_test([A]) where convert(nvarchar(max),’xxx’)

 (3)查询语句:

       cast函数:     select * from tb_test where cast([A] as nvarchar(max))=’xxx’

       convert函数:select * from tb_test where convert(nvarchar(255),test)=’xxx’