用SQL语句取字符串:123 1234 12345 或者123 1234 用1个语句取出123; 用1个语句取出1234;12345或有或无 50

如取123:selectsubstr('123123412345','1',instr('123123412345','',1,1))fromdual... 如取123:select substr('123 1234 12345','1', instr('123 1234 12345',' ',1,1)) from dual 展开
 我来答
yangliwei100
2013-04-17 · TA获得超过2258个赞
知道小有建树答主
回答量:2216
采纳率:50%
帮助的人:721万
展开全部
select (case when charindex('123','123 1234 12345')<>0 then substring('123 1234 12345',charindex('123','123 1234 12345'),3) else '无' end) from [DefaultTable]

其中 [DefaultTable]表示这些字符串存储的表。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
zzkongfu
2013-04-18 · TA获得超过154个赞
知道小有建树答主
回答量:160
采纳率:0%
帮助的人:106万
展开全部
不太清楚你的意思,猜是想用空格把数分开,

declare
n
number;

res
varchar2(100);

str
varchar2(100);

begin
n
:=3;

str
:='123 1234 12345';

select
substr(' '||str||' ',

instr
(' '||str||' ',' ',1, n)+1,

instr
(' '||str||' ',' ',1, n+1)-instr(' '||str||' ',' ',1,n)-1)into res

from dual;

dbms_output.put_line
(res);

END
;

n 表示想拿第几个数,
本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
c6iz
2013-04-17 · TA获得超过1417个赞
知道大有可为答主
回答量:1426
采纳率:100%
帮助的人:1039万
展开全部
SELECT case wheninstr(name,' ',1,1)<>0 then substr(name,'1', instr(name,' ',1,1)) else null end '列名'
FROM 表名

试试这个吧
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(1)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式