用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
展开
展开全部
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]表示这些字符串存储的表。
其中 [DefaultTable]表示这些字符串存储的表。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
不太清楚你的意思,猜是想用空格把数分开,
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 表示想拿第几个数,
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 表示想拿第几个数,
本回答被网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
SELECT case wheninstr(name,' ',1,1)<>0 then substr(name,'1', instr(name,' ',1,1)) else null end '列名'
FROM 表名
试试这个吧
FROM 表名
试试这个吧
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询