[转帖]MySql切分字符串,SUBSTRING用法 _MySQL, Oracle及数据库讨论区_Weblogic技术|Tuxedo技术|中间件技术|Oracle论坛|JAVA论坛|Linux/Unix技术|hadoop论坛_联动北方技术论坛  
网站首页 | 关于我们 | 服务中心 | 经验交流 | 公司荣誉 | 成功案例 | 合作伙伴 | 联系我们 |
联动北方-国内领先的云技术服务提供商
»  游客             当前位置:  论坛首页 »  自由讨论区 »  MySQL, Oracle及数据库讨论区 »
总帖数
1
每页帖数
101/1页1
返回列表
0
发起投票  发起投票 发新帖子
查看: 2427 | 回复: 0   主题: [转帖]MySql切分字符串,SUBSTRING用法         下一篇 
wongz
注册用户
等级:新兵
经验:46
发帖:55
精华:0
注册:2011-8-6
状态:离线
发送短消息息给wongz 加好友    发送短消息息给wongz 发消息
发表于: IP:您无权察看 2015-1-8 11:36:28 | [全部帖] [楼主帖] 楼主

1、从左开始截取字符串

left(str, length)


说明:left(被截取字段,截取长度)
例:select left(content,200) as abstract from my_content_t
2、从右开始截取字符串

right(str, length)


说明:right(被截取字段,截取长度)
例:select right(content,200) as abstract from my_content_t
3、截取字符串

substring(str, pos)
substring(str, pos, length) //length:CHAR_LENGTH(package_price)


说明:substring(被截取字段,从第几位开始截取)

substring(被截取字段,从第几位开始截取,截取长度)


例:select substring(content,5) as abstract from my_content_t

select substring(content,5,200) as abstract from my_content_t
(注:如果位数是负数 如-5 则是从后倒数位数,到字符串结束或截取的长度)


4、按关键字截取字符串

substring_index(str,delim,count)


说明:substring_index(被截取字段,关键字,关键字出现的次数)
例:select substring_index("blog.jb51.net","。",2) as abstract from my_content_t
结果:blog.jb51
(注:如果关键字出现的次数是负数 如-2 则是从后倒数,到字符串结束)

函数简介:

SUBSTRING(str,pos) , SUBSTRING(str FROM pos) SUBSTRING(str,pos,len) , SUBSTRING(str FROM pos FOR len)


不带有len 参数的格式从字符串str返回一个子字符串,起始于位置 pos。带有len参数的格式从字符串str返回一个长度同len字符相同的子字符串,起始于位置 pos。 使用 FROM的格式为标准 SQL 语法。也可能对pos使用一个负值。假若这样,则子字符串的位置起始于字符串结尾的pos 字符,而不是字符串的开头位置。在以下格式的函数中可以对pos 使用一个负值。

详细出处参考:http://www.jb51.net/article/27458.htm

自己在实践项目中遇到的问题

对数据库中地段值进行排序,但是数据如下格式:

$120
$6
¥6
$9
¥220
asaa
¥3


我的要求是中文,英文价格的时候按照升序排列。

SELECT substring(webProduct.package_price,2) as ppvalue FROM website_product_quotation webProduct  order by  ppvalue+0 asc


这个就好了咯!~哦也!

--转自 北京联动北方科技有限公司




赞(0)    操作        顶端 
总帖数
1
每页帖数
101/1页1
返回列表
发新帖子
请输入验证码: 点击刷新验证码
您需要登录后才可以回帖 登录 | 注册
技术讨论