我正在使用一个复杂的数据结构,我不太确定如何在单个 SQL 查询中解决它,尽管我的直觉告诉我这应该是可能的。
我所做的本质是尝试根据所选硬件模型显示给定供应商的可用计划的结果。结果应仅遵循可能的组合,并且计划包含当前作为键/值对存储在限制表中的限制。以下是我正在使用的简化:
(我将使用无线设备进行类比,因为几乎每个人都熟悉手机)
型号表
model_id
vendor_id
is_data
is_voice
is_4g
is_3g
样本数据:
model_id,vendor_id,is_data,is_voice,is_4g,is_3g
DeviceA,Sprint,1,1,0,1
DeviceB,Sprint,1,0,1,0
DeviceC,Sprint,0,1,0,0
DeviceD,Sprint,0,1,0,0
DeviceE,Sprint,0,1,0,0
DeviceF,Verizon,1,1,0,1
DeviceG,Verizon,1,0,1,0
DeviceH,Verizon,0,1,0,0
DeviceI,Verizon,0,1,0,0
DeviceJ,Verizon,0,1,0,0
DeviceK,Tmobile,1,1,0,1
DeviceL,Tmobile,1,0,1,0
DeviceM,Tmobile,0,1,0,0
DeviceN,Tmobile,0,1,0,0
DeviceO,Tmobile,0,1,0,0
计划表
plan_id
vendor_id
name
样本数据:
plan_id,vendor_id,name
PlanA,Sprint,Big Data Only Plan
PlanB,Verizon,Small Data Only Plan
PlanC,Sprint,300 Min Plan
PlanD,Verizon,900 Min Plan
PlanE,Verizon,Big Data Only Plan
PlanF,Tmobile,Small Data Only Plan
PlanG,Tmobile,300 Min Plan
PlanH,Tmobile,1000 Min Plan
plan_restrictions 表
restriction_id
vendor_id
plan_id
type
value
样本数据:
restriction_id,vendor_id,plan_id,type,value
1,Sprint,PlanA,radio,3G
2,Sprint,PlanA,device_type,data
3,Verizon,PlanB,radio,4G
4,Sprint,PlanC,radio,3G
5,Sprint,PlanC,device_type,voice
6,Verizon,PlanD,radio,3G
7,Verizon,PlanD,device_type,voice
8,Verizon,PlanE,radio,3G
9,Verizon,PlanE,device_type,voice
10,Tmobile,PlanF,device_type,data
11,Tmobile,PlanG,device_type,voice
12,Tmobile,PlanH,device_type,voice
键控限制(实际上我接近 50,这是相同类型的表示):
type / value possibilities
radio / 3g, 4g
device_type / data, voice
我对重组表以使其更容易重新查询的可能性持开放态度,但是我需要保留一定的灵活性,因为我确实有大约 1000 个模型、1000 个计划和大约 2000 个限制。
我个人认为这里存在某种结构问题,即。模型可能应该将它们的元素作为键/值对放在一个单独的表中,但这更加复杂,而且我还没有确定如何首先正确应用数据驱动的限制。