SQL 查询 - 提取单元格值以进行如下计算
信息:服务器版本:5.1.39
PHP: 5.4
MySQL/phpMyAdmin
服务器: Apache
代码通过以下方式运行:服务器 SQL 查询(在 phpMyAdmin 中复制并粘贴)或在 MySQL Workbench 中或使用自定义购物车管理器。
导出至: Excel(.csv,然后导出至 .xlsx 以获取销售报告)
其他:我确实使用了一些表格作为引用
我正在尝试编写一个字符串(到目前为止 WHEN 和 IF)来执行以下操作:
T5.coupon_code = XYZABC
AND T3.products_id=14 then the value is $5.00
as Ded_Promo
T5.coupon_code = XYZABC
AND (T3.products_id=Anything else) then the value is $0.00
as Ded_Promo
(例如,请参见表第 1 行和第 2 行)。
尝试过的代码:
(IF(T5.coupon_code=XYZABC And T3.products_id=14,'5.00','0.00')) As Ded_promo2,
结果:错误代码:1054。“字段列表”中存在未知列“XYZABC”
优惠券代码值是合法的,当我对优惠券代码运行查询时,我想要查询的代码显示为正在使用。 (XYZABC 替换为我的真实代码)。
还尝试过:
CASE When (T5.coupon_code = XYZABC) then '5.00'
end As Ded_Promo,
与上面相同的错误。
然后我需要进一步扩展代码以显示:
If code & product match = $5.00 As Ded_Promo (as above)
但如果存在代码(例如 ID:ABC123DEF),则“值”(如所列)为 Disc_CoupVal
理想情况下,我需要确保促销折扣不会归因于订单中的其他产品,而前端将其计算为 1 次销售。我的报告要求我保留仅与他们正在打折的产品相关的折扣优惠券和特别促销事件。佣金依赖于此。
但是,我仍然需要查看列出的所有其他优惠券,并将它们归因于 1 件或多件产品的整个订单。
任何给定订单中的 coupon_code
数量绝不会超过 1 个,商店不允许。
从上面:
orderid | couponcode | ProdID | Discount
21 | XYZABC | 14 | 5.00
21 | XYZABC | 12 | 0.00
36 | ABC123DEF | 3 | 2.50
最佳答案
(IF(T5.coupon_code=XYZABC And T3.products_id=14,'5.00','0.00')) As Ded_promo2
这会导致错误,因为您使用 XYZABC 作为列名。将其用作字符串:
(IF(T5.coupon_code='XYZABC' And T3.products_id=14,'5.00','0.00')) As Ded_promo2
编辑:
为了回应您的评论,您可以将它们包含在同一列中,但这有点困惑:
(IF(
T5.coupon_code='XYZABC' And T3.products_id=14,
'5.00',
(IF(
T5.coupon_code='AnyotherCoupon' And T3.products_id='AnyotherID',
'CouponValue',
'0.00'))
)) As Ded_promo2,
因此,如果代码是 XYZABC
并且产品 ID 是 14
,上面将显示 5
。
否则,如果代码为 AnyotherCoupon
并且 id 为 AnyotherID
,它将显示 CouponValue
。
如果这两种情况都不是,则会显示 0.00
。
需要注意的一点是,如果有很多这样的促销金额,最好将促销金额存储在数据库中(也许作为优惠券表?)。这使 SQL 更加简洁,并允许您更轻松地添加和更改优惠券。
关于MySQL 查询 - IF 或 CASE 以及 AND 和异常(exception)(用于计算),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20612927/