- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有3张 table
price_history (Primary: id)
+----+------------+------+---------+-------+------------+
| id | id_product | sku | id_shop | price | date_add |
+----+------------+------+---------+-------+------------+
| 1 | 11 | 101 | 1001 | 10 | 2017-07-01 |
| 2 | 12 | 101 | 1002 | 15 | 2017-07-01 |
| 3 | 13 | 101 | 1003 | 20 | 2017-07-01 |
| 4 | 11 | 101 | 1001 | 11 | 2017-07-02 | <-- lowest latest
| 5 | 14 | 102 | 1001 | 45 | 2017-07-01 |
| 6 | 15 | 102 | 1002 | 45 | 2017-07-01 |
| 7 | 16 | 102 | 1003 | 45 | 2017-07-01 | <-- shop 1003 is the lowest,
latest among shops and should not be display, because the shop monitored is 1001
| 8 | 15 | 102 | 1002 | 60 | 2017-07-02 |
| 9 | 14 | 102 | 1001 | 55 | 2017-07-02 |
|10 | 17 | 103 | 1001 | 90 | 2017-07-01 |
|11 | 18 | 103 | 1002 | 90 | 2017-07-01 |
|12 | 19 | 103 | 1003 | 90 | 2017-07-01 |
|13 | 17 | 103 | 1001 | 100 | 2017-07-02 | <-- lowest latest
|14 | 18 | 103 | 1002 | 100 | 2017-07-02 |
|15 | 19 | 103 | 1003 | 100 | 2017-07-02 |
+----+------------+------+---------+-------+------------+
product (primary: id_product)
+------------+---- ---+-----+--------------+---------+
| id_product | active | sku | product_name | id_shop |
+------------+--------+-----+--------------+---------+
| 11 | 1 | 101 | Red | 1001 |
| 12 | 1 | 101 | A bit red | 1002 |
| 13 | 1 | 101 | Very red0 | 1003 |
| 14 | 1 | 102 | Blue | 1001 |
| 15 | 1 | 102 | A bit blue | 1002 |
| 16 | 1 | 102 | Very blue | 1003 |
| 17 | 1 | 103 | Green | 1001 |
| 18 | 1 | 103 | A bit green | 1002 |
| 19 | 1 | 103 | Very green | 1003 |
| 20 | 0 | 104 | Discontinued | 1001 |
| 21 | 0 | 104 | Out of stock | 1002 |
| 22 | 0 | 104 | Varnish | 1003 |
+------------+--------+-----+--------------+---------+
shop (primary: id_shop)
+---------+--------+
| id_shop | name |
+---------+--------+
| 1001 | Shop A |
| 1002 | Shop B |
| 1003 | SHop C |
+---------+--------+
每个商店都有不同的产品名称,但有国际编号 (sku)。
要监控的店铺ID:1001(A店铺)
已经在 stackoverflow 中搜索,但找不到正确的。我怎样才能获得每个 SKU 的最低和最新价格。我还是个新手,不明白子选择
这就是我到目前为止所做的
SELECT pph.id, s.name, h2.price, h2.sku
FROM (
SELECT MAX(h.id) max_id, MIN(h.price) min_price, h.id, h.id_shop
FROM price h
GROUP BY sku
) pph
LEFT JOIN price h2 ON (h2.id = max_id)
LEFT JOIN shop s ON (s.id_shop = pph.id_shop)
然后最后我只需要显示受监控的商店“Shop A”
预期结果:
+----+------------+------+---------+-------+
| id | id_product | sku | id_shop | price |
+----+------------+------+---------+-------+
| 4 | 11 | 101 | 1001 | 11 |
|13 | 17 | 103 | 1001 | 100 |
+----+------------+------+---------+-------+
sku 102 的最低价格是商店 1003,因此我们不需要向他们展示。
JSFiddle http://sqlfiddle.com/#!9/ba3a2
谢谢
需要帮助,仍未找到解决方案
最佳答案
您可以使用带有限制子句的相关子查询简单地实现此目的:
select *
from price_history h
where id_shop = 1001
and id = (select id
from price_history p
where h.sku = p.sku
and h.id_shop = p.id_shop
order by date_add desc, price asc
limit 1
);
以上是简单的解决方案,但对于较大的数据集可能会遇到性能问题。
您可以使用以下基于连接的解决方案:
select *
from price_history
join (
select sku, date_add, min(price) as price
from price_history
join (
select sku, max(date_add) as date_add
from price_history
where id_shop = 1001
group by sku
) t using (sku, date_add)
where id_shop = 1001
group by sku, date_add
) t using (sku, date_add, price)
where id_shop = 1001
或
select *
from price_history
join (
select sku, date_add, id_shop, min(price) as price
from price_history
join (
select sku, id_shop, max(date_add) as date_add
from price_history
where id_shop = 1001
group by sku, id_shop
) t using (sku, date_add, id_shop)
group by sku, date_add, id_shop
) t using (sku, date_add, price, id_shop);
关于MySQL 每个产品的最低和最新价格,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44857124/
我需要一些帮助。 我希望“总计”由“数量*价格=总计”计算(到目前为止没问题)。问题是我还需要通过“总/价格=数量”来计算“数量”,即如果一个字段发生更改,另一个字段也会自动更改。 我做了一个非常简单
我试图将每件商品的数量和价格相乘来计算总数,但我的警报中出现错误。 $.each(data.items, function(index, d){ var calcultest = d.pric
我想获得格式化的价格但没有货币符号,我只想使用 magento 的标准功能! $product->getFinalPrice(); => 19.9900 Mage::helper('core')->f
我正在尝试获取特定月份和年份中所有父类别的总价格。父类别是 parent_id == 0 的任何类别。我的查询如下所示: SELECT ROUND(SUM(od.total_price)) a
请帮我摆脱我的头痛..提前我为我的糟糕语言道歉,无论是英语还是mysql。希望有人能理解这个问题..:) 我有一个数据库,任何人都可以记录各个商店中各种产品的价格。以下查询是一个半理论示例,可能根本不
下面是我需要在数据库中设计的示例: 会有一个价格选项,如果有的话,会有一个特价选项,然后我想知道如果我希望其中一个选项是“免费”的,我该怎么做。 另请参阅根据所在国家/地区会有不同的货币。这是我的想法
商品价格格式 999,99 999 - 1 ..4 digits , - comma sign marks decimal point 99 - 2 digits after price Postg
我有这个表 stk +---------+--------------+ | Field | Type | +---------+--------------+ | id
是否有一个简单的格式化程序可以将我的字符串格式化为价格? 所以我的字符串是:300000 我想用空格来“300 000” or 1000000 "1 000 000" 张国荣 最佳答案 这样做: St
我想知道是否可以使用不依赖于 Excel 应用程序本地化(欧盟/美国)的 Excel 公式来自定义数字格式? 例如,我的值为 1291660。 然后使用公式=TEXT(A1;"# ##0,00") .
这是我的代码,对于价格 slider : $("#price-slider").ionRangeSlider({ min: 130, max: 575, onChange :
用户可以使用价格创建一个新实体。价格可以使用不同的货币(EUR,USD ...),因此我们可以乘以(price * convert_rate)得到实际价格。 我想做的是根据价格过滤记录,具体取决于前端
我正在尝试隐藏小数位在类型输入字段上,例如 数字从0.00开始 因此,输入字段中的第一个位置将为 0.00 我输入的1比它应该变成0.01 我输入的2比它应该变成0.12 比 0 所以它应该变成 1.
$res=mysql_query($qry); while($row= mysql_fetch_array($res)) { echo "".$row['Food_Name']." ".$row['P
我们正在为我们的新项目寻找信用卡网关。那里一片困惑,所有人都想把你切成碎片。每次我与他们交谈时,他们都有不同的费率,每次更新报价时,他们都会更改一些价格。 我们正在使用 .net、C#、asp.net
我已经创建了一个 jQuery 价格 slider ,但我不确定如何让过滤区域以实际价格范围开始?目前它有“$[object Object] - $[object Object]”,而我希望它有“$2
我已经创建了 jquery 价格 slider ,但我不确定如何过滤我的结果,以便在滑动时您只能看到具有该值范围内的产品。 HTML: Price range:
我有一个页面,其中有一个表格,我们可以在其中选择一个产品,输入它的数量和价格,然后应在最后一列中计算金额,并应添加新行以输入更多产品,直到我们完成为止。
我创建了电子商务网站,即将提供午餐和晚餐服务。我在这里提出问题/问题是因为我知道这里有很多可以帮助我的传奇人物。我在网站上添加了套餐/计划部分。 1. Weekly 2. Monthly 以下是订
我的网站需要一个简单的 jQuery 价格 slider 。从 0 英镑到 1000 英镑不等。 假设浏览器将 slider 设置为 100 英镑(例如),然后我需要一个立即购买按钮,该按钮将 sli
我是一名优秀的程序员,十分优秀!