当前位置:  数据库>mysql

mysql中取字符串中的数字的语句

    来源: 互联网  发布时间:2014-10-04

    本文导语:  代码如下: one: declare @s varchar(20) declare @i varchar(20) set @i='' set @s='新会员必须购买350元产品' while PATINDEX ('%[0-9]%', @s)>0 begin set @i=@i+substring(@s,PATINDEX ('%[0-9]%', @s),1) set @s=stuff(@s,1,PATINDEX ('%[0-9]%', @s),'') end select @i -- 300 two: declare @a table...

代码如下:

one:
declare @s varchar(20)
declare @i varchar(20)
set @i=''
set @s='新会员必须购买350元产品'
while PATINDEX ('%[0-9]%', @s)>0
begin
set @i=@i+substring(@s,PATINDEX ('%[0-9]%', @s),1)
set @s=stuff(@s,1,PATINDEX ('%[0-9]%', @s),'')
end
select @i
--
300
two:
declare @a table(id int identity(1,1),a varchar(100))
insert @a select '新会员必须购买350元产品'
union all select '新店首次定货必须满20000元'

select left(right(a,len(a)-patindex('%[0-9]%',a)+1),len(right(a,len(a)-patindex('%[0-9]%',a)+1))-1) from @a

上在的

select substring(所查询字符串,patindex('%[^0-9][0-9]%',所查询字符串)+1,patindex('%[0-9][^0-9]%',所查询字符串)-patindex('%[^0-9][0-9]%',所查询字符串)) 这个只能查询第一次在字符串出现的数字串

那么如果出现字符串什么样子的呢 sss8989sss http://www. ss8989ss8989ss8989 7879aafds789 432432432543534 应该怎么取呢


实例
代码如下:

create function fn_GetNum(@s varchar(8000))
returns varchar(8000)
as
begin
select @s = stuff(stuff(@s, 1, patindex('%[0-9, .]%', @s) - 1, ''),
patindex('%[^0-9, .]%', stuff(@s, 1, patindex('%[0-9, .]%', @s) - 1, '')),
len(@s), '')
return @s
end

declare @t table(s varchar(8000))
insert @t select 'aaa11112bbb'
union all select 'ccc212sss'
union all select 'sss21a'
select dbo.fn_GetNum(s) as result from @t

select substring(s,patindex('%[^0-9][0-9]%',s)+1,patindex('%[0-9][^0-9]%',s)-patindex('%[^0-9][0-9]%',s)) from @t

/*功能:获取字符串中的字母*/
CREATE FUNCTION dbo.F_Get_STR (@S VARCHAR(100))
RETURNS VARCHAR(100)
AS
BEGIN
WHILE PATINDEX('%[^a-z]%',@S)>0
BEGIN
set @s=stuff(@s,patindex('%[^a-z]%',@s),1,'')
END
RETURN @S
END
GO
--测试
select dbo.F_Get_STR('测试ABC123ABC')
GO
/*
功能:获取字符串中的数字
*/
create function dbo.F_Get_Number (@S varchar(100))
returns int
AS
begin
while PATINDEX('%[^0-9]%',@S)>0
begin
set @s=stuff(@s,patindex('%[^0-9]%',@s),1,'')
end
return cast(@S as int)
end
--测试
---select dbo.F_Get_Number('测试AB3C123AB5C')
GO


这样之后不管你是那种组合我们都可以方便的把字符中的数字全部取出来。

    
 
 

您可能感兴趣的文章:

  • mysql中字符串和时间互相转换的方法(自动转换及DATE_FORMAT函数)
  • mysql查询字符串替换语句小结(数据库字符串替换)
  • sqlserver、mysql获取连接字符串步骤
  • mysql中向表中某字段追加字符串的方法
  • 浅析MySQL之字符串函数
  • MySQL中随机生成固定长度字符串的方法
  • mysql截取的字符串函数substring_index的用法
  • 批量替换 MySQL 指定字段中的字符串
  • mysql获取字符串长度函数(CHAR_LENGTH)
  • 关于Mysql查询带单引号及插入带单引号字符串问题
  • mysql替换表中的字符串的sql语句
  • 用MySQL函数清除字符串首尾空白字符的方法
  • MySQL笔记之字符串函数的应用
  • mysql 截取指定的两个字符串之间的内容
  • mysql 字符串长度计算实现代码(gb2312+utf8)
  • MySQL replace函数替换字符串语句的用法
  • Mysql字符串截取函数SUBSTRING的用法说明
  • MySQL里实现类似SPLIT的分割字符串的函数
  • mysql like查询字符串示例语句
  • MySQL 字符串模式匹配 扩展正则表达式模式匹配
  • MySQL 字符串函数大全
  • mysql中查询当前正在运行的SQL语句并找出mysql中运行慢的sql语句
  • mysql 里面的sql语句的连接字符是什么?急用!
  • Mysql增加主键或者更改表的列为主键的sql语句
  • MYSQL速度慢的问题 记录数据库语句
  • Mysql下在某一列后即表的某一位置添加新列的sql语句
  • 允许远程用户访问mysql服务sql语句
  • mysql update语句的用法详解
  • mysql自定义排序顺序语句
  • mysql查询语句通过limit来限制查询的行数
  • mysql快速添加百万条记录的语句
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • mysql中如何判断当前是字符 mysql判断字段中有无汉字
  • mysql4.0升级到mysql5(4.1),解决字符集问题
  • mysql修改数据库编码(数据库字符集)和表的字符编码的方法
  • Mysql 默认字符集设置方法(免安装版)
  • MySQL字符集的基本类型与统一字符集分析
  • php mysql转义特殊字符的函数有哪些?
  • mysql字符集和数据库引擎修改方法分享
  • php mysql转义特殊字符函数
  • linux下安装mysql字符集转换的问题
  • mysql odbc字符集设置(中文显示乱码)
  • 基于mysql 5.5 设置字符集问题的详解
  • MySQL用户密码中的特殊字符叹号(!)的妙用
  • MySQL 转义字符使用说明
  • MySQL数据入库时特殊字符处理详解
  • 深入MYSQL字符数字转换的详解
  • mysql安装后添加gbk字符集的方法
  • 烦人:用Java操纵mySQL数据库时的中文字符处理。
  • 解析在MYSQL语法中使用trim函数删除两侧字符
  • mysql 字符集的系统变量说明
  • mysql 常用设置 字符集编码、自动完成(自动提示)、监听外网ip
  • mysql中如何查看最大连接数(max_connections)和修改最大连接数
  • 在 linux下输入"mysql"命令,进入mysql命令行,但出现“Can't connetc to local MySQL server thuough socket /var/lib/mysql/mysql.sock
  • Mysql查询错误:ERROR:no query specified原因
  • MySQL 重装MySQL后, mysql服务无法启动
  • php安装完成后如何添加mysql扩展
  • 为什么用linux安装盘安装了mysql后,启动mysql,提示找不到mysql.sock文件?
  • Myeclipse中自带Tomcat的JDBC连接池配置(mysql和mssql)
  • 請教,在redhat linux7.2+mysql 中,系統提示mysql已啟動,網頁卻不能訪問mysql?
  • MySQL Workbench的下载安装与使用教程
  • 求解释: useradd -g mysql mysql -d /home/mysql -s /sbin/nologin
  • php中内置的mysql数据库连接驱动mysqlnd简介及mysqlnd的配置安装方式


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3