MySQL中截取表字段值的部分数据

背景

有的时候,我们需要截取数据表中某字段的一部分数据,比如某个地域下有很多地区,同一地域前缀相同,地区不同,后缀也不同,假设10001,10002表示的是同一地域下的不同地区,那么我们想要统计这个地域信息该怎么处理呢?有人说直接加个地域的字段不就行了,其实这也是一种办法,但是如果表中字段比较多,或者业务上不允许加个字段解决,那这个时候我们该怎么截取地区字段值的前缀用来获取地域值呢?

其实数据库提供了left和right两个函数帮助我们截取字段值,分别是

left(reg_id, 3)
right(org_id, 2)

他们分别表示从reg_id中截取前三位,从org_id中截取后两位,下面看两个具体的SQL例子

此外还有substring函数,它可以从字段中间截取,但是没法截取查询出的结果中的字段值

substring(reg_id, 0, 2) #截取reg_id的前两位

案例

根据地域reg_id的前四位即地区用res_id表示进行分组统计,统计各地区的总用电量,总充电次数

注意这里只能用left而不能用substring,因为substring无法在group by中使用

<select id="getResRecords" parameterType="string" resultType="OperatingCountDto">
   select reg_id,LEFT(reg_id,4) as resId, sum(total_kwh) as totalKwh,
        sum(total_times) as totalTimes from ${tableName} 
        where LEFT(reg_id,4) is not null GROUP BY LEFT(reg_id,4);
</select>
  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

BirdMan98

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值