在SQL Server中插入®特殊字符

 

今天群里一个朋友问如何插入® 特殊字符,我做了几次测试都没有成功,很郁闷,后来有人说在插入的字符串前加N就可了,我试了一下果然可以

update t_test set test_text = '® '     不成功

update t_test set test_text = N'® '   成功

为什么呢,MSDN上原文是这样子说的:

-----------------------------------------------------------------------------

使用 N 前缀

在服务器上执行的代码中(例如在存储过程和触发器中)显示的 Unicode 字符串常量必须以大写字母 N 为前缀。即使所引用的列已定义为 Unicode 类型,也应如此。如果不使用 N 前缀,字符串将转换为数据库的默认代码页。这可能导致不识别某些字符。

例如,在前面示例中创建的存储过程可以按以下方式在服务器上执行:复制代码
EXECUTE Product_Info @name = N'Chain'

使用 N 前缀的要求适用于服务器上产生的字符串常量和从客户端发送的字符串常量。

-------------------------------------------------------------------------------

原来我们平时在往服务器上传送字符串时它会将字符串处理为服务器商的Unicode字符串然后再插入到SQL数据库中,如果加上N之后他就会直接使用客户端传过来的字符串。

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值