mysql sql 语句sum求和嵌套数学表达式

今天有个需求, 已减高度 = 高度 x 单双开(单开1 双开2) x 2,要直接写在sql语句中。

表字段 包含 高度 和 单双开字段 值是字符串 (双开 左单开 右单开)

-- 已减高度 = 2 * 单双开 * 高度
sum(
-- 求和 表达式  已减高度 = 2 * 单双开 * 高度
t_cloth.hegiht * 2 *
(case WHEN  locate('双开',t_cloth.open_with) > 0 then 2
when locate('双开',t_cloth.open_with) <= 0 then 1
end)
)  as hegiht_sum,

locate(字符,字段名)

使用locate(字符,字段名)函数,如果包含,返回>0的数,否则返回0 ,
它的别名是 position in
select * from 表名 where locate(字符,字段)
select * from 表名 where position(字符 in 字段);
例子:判断site表中的url是否包含’http://'子串,如果不包含则拼接在url字符串开头
update site set url =concat(‘http://’,url) where locate(‘http://’,url)=0

参考资料 大神博客

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值