欢迎来到Doc100.Net免费学习资源知识分享平台!
您的位置:首页 > 程序异常 >

oracle 存储过程 判断字段中是否包含指定的字符,该怎么解决

更新时间: 2014-01-05 02:11:27 责任编辑: Author_N1

 

oracle 存储过程 判断字段中是否包含指定的字符
表(NN_TEST)中某个字段(NN_VALUE)的值:
1,22,3,4,5

我想判指定的数字是否在这个字段中,
比如我想判断 2  不是 22 

select * from NN_TEST t
WHERE instr(NN_VALUE, '2')>0 
这个查询语句是有结果的, 
应该没有查询结果的,因为2不存在。

请教大侠们,指点一下。
--参考方法--
regexp_instr

参考这个http://blog.sina.com.cn/s/blog_6288f1400100lv79.html
--参考方法--

select * from NN_TEST t
where instr(','
--参考方法--
NN_VALUE
--参考方法--
',',',2,')>0;

--参考方法--
逗号分割的。
那么可以
select * from NN_TEST t
WHERE instr(NN_VALUE, '2,')>0
--参考方法--
引用:
SQL code

select * from NN_TEST t
where instr(','
--参考方法--
NN_VALUE
--参考方法--
',',',2,')>0;

很妙啊。

with t(str) as (
select '33,22,2' from dual 
union
select '2,32,42' from dual 
union 
select '222,2222,22' from dual 
)
select str,regexp_instr(str,'^[2],
--参考方法--
,[2]$') from t order by str ;

STR         REGEXP_INSTR(STR,'^[2],
--参考方法--
,[2]$')
----------- -------------------------------
2,32,42                                   1
222,2222,22                               0
33,22,2                                   6



--参考方法--
+1
引用:
SQL code

select * from NN_TEST t
where instr(','
--参考方法--
NN_VALUE
--参考方法--
',',',2,')>0;

我的异常网推荐解决方案:oracle存储过程,http://www.myexception.cn/oracle-develop/177537.html
上一篇:上一篇
下一篇:下一篇

 

随机推荐程序问答结果

 

 

如对文章有任何疑问请提交到问题反馈,或者您对内容不满意,请您反馈给我们DOC100.NET论坛发贴求解。
DOC100.NET资源网,机器学习分类整理更新日期::2014-01-05 02:11:27
如需转载,请注明文章出处和来源网址:http://www.doc100.net/bugs/t/6785/
本文WWW.DOC100.NET DOC100.NET版权所有。