SQL语句通配符查询, 怎么查找 中括号 []

SQL语句通配符查询,怎么查找中括号[]例如查找[大写字母]patindex(string,'%[A-Z]%').中括号咋么查?转义符patindex('%\[[A-Z]... SQL语句通配符查询, 怎么查找 中括号 []
例如查找 [大写字母]
patindex(string, '%[A-Z]%').
中括号咋么查?
转义符patindex( '%\[[A-Z]\]%', string). 不成功
刚才写错而已。 依然不支持。 系统自动匹配如图:
sungun07真复杂。 其实我就是想通配查找: [大写字母]
展开
 我来答 举报
hy1397471
推荐于2017-09-02 · 知道合伙人软件行家
hy1397471
知道合伙人软件行家
采纳数:4714 获赞数:17154
15年数据库维护及数据库应用系统开发经验,从事零售业、服务业及财务管理类系统开发与维护。

向TA提问 私信TA
展开全部

SQL 通配符[]使用有两种

1、[charlist]    字符列中的任何单一字符   

2、[^charlist]或者[!charlist] 不在字符列中的任何单一字符



以图中表格为例,

1、查询居住的城市以 "A" 或 "L" 或 "N" 开头的人:

SELECT * FROM Persons WHERE City LIKE '[ALN]%'

2、查询居住的城市不以 "A" 或 "L" 或 "N" 开头的人:

SELECT * FROM Persons WHERE City LIKE '[!ALN]%'

lanph47
2011-01-08 · TA获得超过574个赞
知道答主
回答量:347
采纳率:0%
帮助的人:289万
展开全部
搂主说得不是太明白,你是要取第一条记录所对应的那个时间吗?
如果是的话,用如下语句即可。

select min(time)
from table1
group by convert(varchar(13),time,20)

假设Table1表中数据如下

2006-05-01 11:01:00.000
2006-05-01 11:02:00.000
2006-05-01 12:02:00.000
2006-05-02 12:02:00.000
2006-05-02 12:01:00.000

查询结果为:
2006-05-01 11:01:00.000
2006-05-01 12:02:00.000
2006-05-02 12:01:00.000

对应的都是每小时中最早的那一条时间。

convert(varchar(13),time,20)
的意思是将time字段转换成字符串形式,convert的第三个参数,取值20是将时间转换成yyyy-mm-dd hh:mm:ss的形式。由于限定了是转换成长度为13的字符串,所以转换后就会取时间字符串的前13位yyyy-mm-dd hh
抢首赞 已赞过 已踩过<
你对这个回答的评价是?
评论 举报 收起
ieicihc
2015-10-01 · TA获得超过108个赞
知道小有建树答主
回答量:89
采纳率:100%
帮助的人:31.4万
展开全部
  1. 用中括号把特殊符号括起来就行了。

  2. 比如:select * from TB_QF where QF_str like '%[[]%[]]%'

1 已赞过 已踩过<
你对这个回答的评价是?
评论(1) 举报 收起
flyingFish211
推荐于2017-09-27 · TA获得超过2.1万个赞
知道大有可为答主
回答量:1.5万
采纳率:50%
帮助的人:1.1亿
展开全部
用转义符号\啊 \[

转义符patindex( '%\[[A-Z]\[%', string). 不成功
patindex( '%\[[A-Z]\]%', string). 你把后边那个括号方向搞反了
本回答被提问者采纳
3 已赞过 已踩过<
你对这个回答的评价是?
评论 举报 收起
VV呀VV
2011-01-18 · 超过20用户采纳过TA的回答
知道答主
回答量:57
采纳率:100%
帮助的人:36.8万
展开全部
--嘿嘿,没弄明白patindex的用法,不好意思
set serveroutput on ;
declare
v_posleft number;
v_posright number;
v_tring varchar2(1024);
v_substr varchar2(502);
begin
--原来的字符串patindex(string, '%[A-Z]%')
v_tring := 'patindex(string, '||chr(39)||'%[A-Z]%'||chr(39)||')';--使用转义字符变化了原来的字符串
v_posleft := instr( v_tring,chr(91));--判断左[
v_posright := instr( v_tring,chr(93),instr( v_tring,chr(91)));--判断右]

select
case when v_posleft>0 then
(case when v_posright>0
then SUBSTR(v_tring, v_posleft+1, v_posright - v_posleft-1)
end)
else 'bbb' end
into v_substr
from dual ;
dbms_output.put_line('子串为:'||v_substr);
end ;
--使用了转义字符char(39) ' char(91) [ char(93) ]

转义字符表参考http://www.itpub.net/thread-201742-1-1.html
抢首赞 已赞过 已踩过<
你对这个回答的评价是?
评论 举报 收起
收起 更多回答(4)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式