SQL2000 N' '的意思

本文探讨了MS-SQLServer 2000与2005版本中使用LIKE进行字符串匹配时出现的问题,特别是在处理包含中文字符的查询时。文章解释了如何通过在字符串前添加N前缀来确保非英文字符串查询的正确执行。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

MS-SQL Serverselect * from Book where BookName like'%C语言%' 在SQL2000下能正常找到,在2005下不能,因为语句中的中文字体, 但是使用select * from Book where BookName like N'%C语言%' ,这样就完合正常了, Like 后的N是表示什么意思呢unicode字符 N转换字符串为nchar,nvarchar 当把客户端发送的非 Unicode 数据以 Unicode 存储在服务器中时,如果具备下列条件之一,则来自任何客户端的任何代码页的数据都可以正确地存储 字符串常量以大写字母 N 开头。无论客户端应用程序是否能够识别 Unicode,必需这样做。如果没有字母 N 前缀,则 SQL Server 会将字符串转换为与数据库的默认排序规则相对应的代码页。此代码页中没有的字符都将丢失。此外,对于非英文字符串查询也应该写成 like N'...'

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值