设为首页
收藏本站
开启辅助访问
切换到窄版
登录
立即注册
中问网首页
我的收藏
站长博客
搜索
搜索
本版
帖子
用户
第一问答网
»
论坛
›
中问网
›
问答
›
如下图,利用SQL Server语句如何查询除了作者中包含“明 ...
返回列表
发新帖
如下图,利用SQL Server语句如何查询除了作者中包含“明”字的其他所有列,即[^明]? 我写的代码:
[复制链接]
11
|
4
|
2013-5-31 17:24:34
|
显示全部楼层
|
阅读模式
明字被第一个%匹配了这和正则表达式一样,比如 '海明威' %匹配了 '海明' ,[^明]匹配了'威' 后面的%什么都没匹配如果你有一个记录作者只有一个 '明' 字那么第一个%匹配 '明'字 然后 [^明] 必须匹配一个字,不符合,这个记录会过滤%匹配时候,是贪婪的,所以第一次尝试会匹配所有,发现[^明]没有匹配的,则放弃最后一个字符,继续匹配所以,你这个like 语句只能去掉只有一个'明'的记录...
回复
使用道具
举报
千问
|
2013-5-31 17:24:34
|
显示全部楼层
select * from表 where 图书编号 not in ( select图书编号 from表 where 作者 like '%明%')好像[^明]sql没识别吧!并且这是用''号括起来的是不会执行判断的,放在外面会报错!这种应该行不通...
回复
使用道具
举报
千问
|
2013-5-31 17:24:34
|
显示全部楼层
你的查询结果是全部是对的,以为%代表了包含部分,[^明]表示不包含明的部分以海明威为例子,其实第一个%已经包含“海明”,而“威”字符合[^明]这个条件,所以是能查询出来的...
回复
使用道具
举报
千问
|
2013-5-31 17:24:34
|
显示全部楼层
你这样只能去除开头为“明”的记录:你可以这样写啊,select *from表where not Exist (select *from表where 作者 like '%明%')...
回复
使用道具
举报
返回列表
发新帖
高级模式
B
Color
Image
Link
Quote
Code
Smilies
您需要登录后才可以回帖
登录
|
立即注册
本版积分规则
发表回复
回帖后跳转到最后一页
千问
主题
0
回帖
4882万
积分
论坛元老
论坛元老, 积分 48824836, 距离下一级还需 -38824837 积分
论坛元老, 积分 48824836, 距离下一级还需 -38824837 积分
积分
48824836
加好友
发消息
回复楼主
返回列表
问答
热门排行