from string get number data using pl/sql or sql

declare   @aa   varchar(80),----INFO列
          @bb   varchar(80)
  
set   @aa   ='你好12按时地方'
set @bb=''
while   PATINDEX('%[0-9]%',@aa)<>0  /*每次循环找出一个数字*/
begin
    set @bb = @bb+substring(@aa,PATINDEX('%[0-9]%',@aa),1)/*把找出来的数字进行相加*/
    set @aa=substring(@aa,1,PATINDEX('%[0-9]%',@aa)-1)+
     substring(@aa,PATINDEX('%[0-9]%',@aa)+1,len(@aa)-PATINDEX('%[0-    9]%',@aa)) /*把找出来的数字从原先的字符串中踢除出来,然后再循环找出更多的数字*/  
end
select @bb/*要求得到的结果*/

猜你喜欢

转载自killdbs.iteye.com/blog/1408284