码迷,mamicode.com
首页 > 数据库 > 详细

sql server 中 like 中文不匹配问题

时间:2019-10-13 18:47:50      阅读:104      评论:0      收藏:0      [点我收藏+]

标签:排序   语言   排序规则   nvarchar   details   前缀   数据   log   转换   

原文:https://blog.csdn.net/miao0967020148/article/details/71108056

MS-SQL Server
select * 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 会将字符串转换为与数据库的默认排序规则相对应的代码页。此代码页中没有的字符都将丢失。

此外,对于非英文字符串查询也应该写成 ike N‘...‘

sql server 中 like 中文不匹配问题

标签:排序   语言   排序规则   nvarchar   details   前缀   数据   log   转换   

原文地址:https://www.cnblogs.com/zhang1f/p/11667124.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!