如何解决sql总结
我有一个配方成分表,基本上我想做的是找到一个配方的价格,四舍五入到整个成分。
所以我写了这个sql。
select recipe_id_label,recipe_name,variation_name,portion_size,menu_id,sum (recipe_order_ingredient_quantity * ingredient_expected_cost)
from mb.weekly_menus_recipes_ingredients
where recipe_id_label = '30943'
and portion_size = '2'
group by recipe_id_label,variation_name
这是有趣的部分。
sum (recipe_order_ingredient_quantity * ingredient_expected_cost)
这个sql得到正确答案,只要没有一半成分。例如,如果您有 0,25 包胡萝卜,它不会四舍五入到 1 包。
然后我尝试了这个。
sum (ingredient_planned_cost* ceiling (recipe_order_ingredient_quantity))
这也不起作用。如果有两行有半根胡萝卜,该 sql 会将这些行中的每一行加起来为 1 根胡萝卜,因此它将计算两根完整的胡萝卜,而不是两半 (1)。
所以基本上我希望我的代码能够理解 half + half 是整体,并且理解即使你只使用四分之一也需要一个整体。
解决方法
这是你想要的吗
select recipe_id_label,recipe_name,portion_size,menu_id,variation_name,sum(ingcost)
from (
select recipe_id_label,ceiling(sum(recipe_order_ingredient_quantity)) * ingredient_expected_cost ingcost
from mb.weekly_menus_recipes_ingredients
where recipe_id_label = 30943 and portion_size = 2
group by recipe_id_label,ingridient_id,ingredient_expected_cost
) t
group by recipe_id_label,variation_name
编辑 使用 MySql 检查语法
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。