【问题标题】:MySQL/PHP storing multiple data pointsMySQL/PHP 存储多个数据点
【发布时间】:2013-01-19 05:39:23
【问题描述】:

我对编程和数据库比较陌生。

我有一个带有“销售”表的 MySQL 数据库。此表列出了一个州的所有销售(即每条记录都是一个特定的销售),其中包含卖方名称和买方zip 字段。我想要另一个表“卖家”,其中包含卖家名称,还包含通过邮政编码定义卖家市场区域的字段 - 比如 50 多个邮政编码定义一个市场,卖家可以定义多个市场。

这些市场区域将用于未来的查询:显示特定市场区域的所有销售额。

我从哪里开始考虑如何存储“市场区域”数据,然后将其用于将来的查询?

谢谢

【问题讨论】:

  • 想象一家零售店 - 商店 A 可能将其市场定义为邮政编码 1,2,3,4,5,6,7,8 - 并将单独的市场定义为 4,5,6 ,7,8,9,10。商店 B 可能将其市场定义为 1、2、3、8、9、10、11、12。我有数据可以显示这些邮政编码中所有卖家对买家的销售情况——因此我可以显示任何特定卖家在任何特定市场中的市场份额。
  • 实际上 - 市场可以小到一个邮政编码,也可以大到几百个邮政编码 - 用户可以定义自己的市场。

标签: php mysql


【解决方案1】:

表结构:

  • 销售表:ID、卖家ID、买家邮政编码、金额
  • 卖家表:ID、卖家名称
  • 市场表:ID、市场名称
  • SellerMarketLink 表:ID、sellerID、marketID
  • MarketZipCode 表:ID、marketID、邮政编码

示例数据

对问题的第一条评论中的信息进行编码

市场表

1、“A店,第一个市场”
2、《A店、第二市场》
3、“B店市场”

MarketZipCode 表

1、1、1
2, 1, 2
...
7、1、7
8、1、8
9、2、4
10、2、5
...
14、2、9
15、2、10
16、3、1
17、3、2
18、3、3
19、3、8
20、3、9
21、3、10
22、3、11
23、3、12

查询

每个卖家在市场中的总销售额。请注意,由于一个邮政编码可以属于多个市场,因此“Total Sales”中所有值的总和可能大于 Sales 表中所有“amount”值的总和。

select Market.marketName, Seller.sellerName, sum(Sales.amount) as "Total Sales"
from Sales join Seller join SellerMarketLink join Market join MarketZipCode
on (Sales.sellerID = Seller.ID AND Seller.ID = SellerMarketLink.sellerID 
  AND SellerMarketLink.marketID = Market.ID 
  AND Market.ID = MarketZipCode.marketID 
  AND MarketZipCode.zipCode = Sales.buyerZipCode)
group by Market.ID, Market.marketName, Seller.ID, Seller.sellerName
order by Market.marketName, Seller.sellerName

【讨论】:

  • 谢谢 - 我的意思是回到这个 - 这就是我要找的 - 如何存储多对多关系
【解决方案2】:

我将在这里做以下假设:

  1. 卖家有很多市场
  2. 一个市场可以跨越多个邮政编码
  3. 只有一个卖家负责一个市场
  4. 市场不能重叠

导致以下结构...

销售表 卖家 |买家zip

市场表 市场| market_zipcodes_id

邮政编码表 市场编号 |邮政编码

希望对您有所帮助...

【讨论】:

  • 1.卖家可以有很多市场 2. 一个市场可以有很多邮政编码 3. 市场上可以有多个卖家,因此市场可以而且确实会重叠。
  • 留给读者作为练习。我已经预先给了你我的假设。如果你想让我为你做这项工作,你必须付钱给我
猜你喜欢
  • 2012-11-26
  • 1970-01-01
  • 1970-01-01
  • 2017-07-22
  • 1970-01-01
  • 1970-01-01
  • 2014-05-18
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多