sql server中not like '%.%'的一个超奇怪问题

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了sql server中not like '%.%'的一个超奇怪问题相关的知识,希望对你有一定的参考价值。

有一张old表,里面有案卷和案件
案卷的案卷号是22这种形式,案件的案卷号是22.222这种形式。我要把old表中案卷导到案卷表,案件导到案件表。通过有无小数点也就是not like '%.%'和like '%.%'来判断是案卷还是案件。可是导完后案卷表中会有案件,也就是案卷表中会有一些案卷号带小数点的。也就是not like没成功。而这些本应该在案件表中的数据没有出现在案件表中。有什么好办法解决啊

参考技术A 绕口令啊?
SQL语句在哪里呢...
select * from old where PATINDEX('.',[案卷号])<>0
获得所有带.的记录.
另外注意.是全角还是半角的.
参考技术B 应该没错吧! 参考技术C %号本身就代码任意自符了,也包括.,所以会产生那样的结果;

方法正在思考中...
参考技术D 你错了哈.不是'%.%'
是%'.'%

sql server 中 like 中文不匹配问题

原文: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中not like '%.%'的一个超奇怪问题的主要内容,如果未能解决你的问题,请参考以下文章

如何在 SQL Server 查询中同时使用 LIKE 和 NOT LIKE

sql 包含于语法

sap hana sql中not like 多个条件

请教sql语句中not like的用法

sqlserver like '%' 性能问题

][SQL Server]关键字 'like' 附近有语法错误。