ฉันกำลังทำงานในจุดขายใหม่สำหรับ บริษัท ที่ผลิตภัณฑ์ในราคาที่แตกต่างกันขึ้นอยู่กับส่วนผสมของผลิตภัณฑ์
ผลิตภัณฑ์ทั้งหมดมีราคาฐาน
เพื่ออธิบายปัญหาของฉันฉันจะใช้ข้อมูลต่อไปนี้:
Product Category Price
A 1 45
B 1 70
Q 2 20
R 2 27
S 2 15
X 3 17
Y 3 22
Z 3 16
บริษัท มีแพ็คเกจเช่นแพ็คเกจ "Combo": สำหรับผลิตภัณฑ์ A หรือ B หากคุณเลือก 1 จาก Q หรือ R และ 1 จาก X, Y หรือ Z คุณจะได้รับส่วนลด $ 20
กรณี A:บางครั้งลูกค้าเพิ่มไปยังผลิตภัณฑ์พื้นฐานเมื่อทำการสั่งซื้อตัวอย่างเช่นพวกเขาไม่ได้เป็นหนึ่งในผลิตภัณฑ์ A และพวกเขาเพิ่มผลิตภัณฑ์ Q และผลิตภัณฑ์ P ไปที่การสร้างแพคเกจที่มีราคาลดราคา จากนั้นพวกเขาอาจเพิ่มว่าพวกเขาต้องการ 1 ของผลิตภัณฑ์ B ที่มี 1 R และ 1 Z
กรณี B:บางครั้งลูกค้าจะเพิ่ม 1 A และ 2 B, 2 Q, 1 S, 2 X และ 1 Z ตามกฎที่กำหนดโดยแพ็คเกจ "Combo" จะมีคอมโบเพียง 2 ตัวเท่านั้นเนื่องจาก S ไม่ใช่รายการคำสั่งผสม
โปรโมชั่นอื่น ๆ ขึ้นอยู่กับปริมาณดังนั้นหากคุณซื้อ 2 of B คุณจะได้รับส่วนลด 20% และ / หรือขึ้นอยู่กับเวลาจะสามารถใช้งานได้หลังเวลา 17.00 น. เท่านั้นและก่อนที่จะลดราคา 10% หากก่อน 10 โมง การส่งเสริมการขายอื่นอาจขึ้นอยู่กับว่าการซื้อครั้งล่าสุดของคุณเกิดขึ้นหรือหากคุณซื้อมากกว่า $ X ในช่วงเวลา Y
ปัญหาของฉัน:
1) ฉันจะจัดโครงสร้างตารางอย่างไรฉันจึงสร้างแพ็คเกจหรือโปรโมชั่นต่าง ๆ ในแบบที่ยืดหยุ่นมากในการเพิ่มประเภทโปรโมชั่นต่าง ๆ ที่มีข้อกำหนดต่างกัน?
2) เมื่อพวกเขาสั่งซื้อเช่น Case B (หรือการผสมผสานของ Case A และ Case B) ฉันจะจัดโครงสร้างคิวรีของฉันอย่างไรเพื่อให้ฉันสามารถทดสอบเพื่อดูว่ามิกซ์ผลิตภัณฑ์ (es) ใดบ้างในการสั่งซื้อและอัปเดตราคา / คำอธิบายตาม ? ในที่สุดผลลัพธ์ที่ดีที่สุดสำหรับการค้นหานี้จะส่งคืนแพคเกจและโปรโมชั่นที่มีความต้องการในการสั่งซื้อเพื่อให้เกิดประโยชน์สูงสุดแก่ลูกค้า (นั่นคือสิ่งที่พวกเขาสั่งให้ตอบสนองความต้องการสำหรับโปรโมชัน 1 และ 3 จะต้องทำงานกับการส่งเสริมการขายหลายรายการ)
ขอบคุณล่วงหน้าสำหรับความช่วยเหลือ!
อัปเดต # 1
เพื่ออธิบายปัญหาในมือให้ดีขึ้นและเพื่อปรับปรุงงานที่ทำไปแล้วเพื่อแก้ไขปัญหาเหล่านี้ฉันกำลังรวบรวม ERD ของรุ่นผลิตภัณฑ์ที่ จำกัด เฉพาะเอนทิตีและคุณลักษณะที่มีผลต่อปัญหา (เช่นไม่มีสินค้าคงคลังอยู่ที่นี่ดังนั้นไม่มีสินค้าคงคลัง ปัจจุบัน)
ฉันยังรวมถึงข้อมูลตัวอย่างจากเอนทิตีและแอตทริบิวต์ที่มีผลกับคำถามนี้ (เพื่อให้การอ่านข้อมูลง่ายขึ้นฉันกำลังใส่ชื่อ / คำอธิบายแทน Foreign Keys):
PRODUCT
---------
ID Name
================================
1 Hamburger
2 Cheeseburger
3 Bacon Hamburger
4 Bacon Cheeseburger
5 Orange Juice
6 Apple Juice
7 Coffee
8 Coke
9 French Fries
10 Onion Rings
11 Soup du Jour
12 Hamburger Combo
13 CheeseBurger Combo
14 Bacon Hamburger Combo
15 Bacon Cheeseburger Combo
16 Combo Side
17 Combo Beverage
18 Small Orange Juice
19 Large Orange Juice
20 Small Apple Juice
21 Large Apple Juice
22 Add Extra Patty
23 Add Avocado
PRODUCT COMPONENT
------------------
productFrom productTo
===================================================
Hamburger Combo Hamburger
Hamburger Combo Combo Side
Hamburger Combo Combo Beverage
CheeseBurger Combo Cheeseburger
CheeseBurger Combo Combo Side
CheeseBurger Combo Combo Beverage
Bacon Hamburger Combo Bacon Hamburger
Bacon Hamburger Combo Combo Side
Bacon Hamburger Combo Combo Beverage
Bacon Cheeseburger Combo Bacon Cheeseburger
Bacon Cheeseburger Combo Combo Side
Bacon Cheeseburger Combo Combo Beverage
PRODUCT FEATURE
----------------
ID Description
=======================
1 Combo Side Option
2 Combo Beverage
3 Juice
4 Orange Juice Size
5 Apple Juice Size
6 Extras
PRODUCT FEATURE APPLICABILITY
------------------------------
product productFeature ProductFeatureApplicabilityType
============================================================================
Hamburger Combo Combo Side Required
Hamburger Combo Juice Flavor Required
Cheeseburger Combo Combo Side Required
Cheeseburger Combo Juice Flavor Required
Bacon Hamburger Combo Combo Side Required
Bacon Hamburger Combo Juice Flavor Required
Bacon Cheeseburger Combo Combo Side Required
Bacon Cheeseburger Combo Juice Flavor Required
PRODUCT FEATURE APPLICABILITY
------------------------------
productFeature product ProductFeatureApplicabilityType
============================================================================
Combo Side Hamburger Combo Required
Combo Beverage Hamburger Combo Required
Extras Hamburger Combo Optional
Combo Side Cheeseburger Combo Required
Combo Beverage Cheeseburger Combo Required
Extras Cheeseburger Combo Optional
Combo Side Bacon Hamburger Combo Required
Combo Beverage Bacon Hamburger Combo Required
Extras Bacon Hamburger Combo Optional
Combo Side Bacon Cheeseburger Combo Required
Combo Beverage Bacon Cheeseburger Combo Required
Extras Bacon Cheeseburger Combo Optional
OPTIONAL FEATURE
------------------
productFeatureFrom Product ProductFeatureTo
=============================================================
Combo Side Option French Fries
Combo Side Option Onion Rings
Combo Side Option Soup du Jour
Combo Beverage Juice
Combo Beverage Coffee
Juice Orange Juice Size
Juice Apple Juice Size
Orange Juice Size Orange Apple Juice
Orange Juice Size Orange Apple Juice
Apple Juice Size Small Apple Juice
Apple Juice Size Large Apple Juice
Extras Add Extra Patty
Extras Add Avocado
ดังนั้นด้วยการวิจัยและการสนับสนุนจากชุมชนจนถึงรู้ฉันสามารถแก้ปัญหา # 1 ได้ ที่จริงแล้วฉันมีความยืดหยุ่นมากกว่าที่ฉันคิดว่าฉันสามารถทำได้ในการปรับใช้ระบบครั้งแรก
แม้ว่าจะมีความก้าวหน้าในปัญหา 2 แต่ก็ไม่ได้รับการแก้ไขเพื่อความพึงพอใจ มีความคิดบางอย่างเกี่ยวกับวิธีการทำเช่นนี้ Neil McGuilgan ถามคำถามที่ยิ่งใหญ่ที่นำไปสู่วิธีแก้ปัญหาที่เป็นไปได้โดยใช้ Relational Division (dba.stackexchange.com/questions/45829/what-is-the-name-of-this-type- of-query-and-what-is-an-an-effective- ตัวอย่าง) และหนังสือเล่มนี้ (www.amazon.com/books/dp/0471380237) ช่วยได้มาก อย่างไรก็ตามการแก้ปัญหานี้ในปัจจุบันและในขณะที่ฉันเข้าใจมันทำงานได้เฉพาะกับบันทึก "หนึ่ง" (คำสั่งผสม) ในแต่ละครั้ง หากลูกค้าเดินเข้ามาและบอกว่าเขาต้องการชีสเบอร์เกอร์ 2 ตัวแฮมเบอร์เกอร์ 1 แก้วน้ำแอปเปิ้ลเล็ก 1 แก้วโค้ก 1 เฟรนช์ฟราย 1 และแหวนหอมใหญ่ 2 ชิ้นฉันต้องการวิธีการตรวจสอบว่ามีคำสั่งผสมเพียงคำเดียวในส่วนผสม ผลิตภัณฑ์ในราคาฐาน หากมีการรวมกันหลายคำสั่งผสมฉัน
แนวคิดหนึ่งที่ฉันคิดขึ้นเพื่อแก้ไขปัญหาที่สองคือการเพิ่มและแอตทริบิวต์ให้กับการทำเครื่องหมายส่วนประกอบของผลิตภัณฑ์เป็นผลิตภัณฑ์หลักสำหรับคอมโบ (เช่นแฮมเบอร์เกอร์) จากนั้นเมื่อเรียกใช้กระบวนการกำหนดราคาให้สอบถามว่าผลิตภัณฑ์ใดในการสั่งซื้อคือผลิตภัณฑ์หลักใน "แพ็คเกจ" ซึ่งเกี่ยวข้องกับการค้นหาส่วนลดที่ได้รับจากตารางส่วนประกอบราคาและการสั่งซื้อตามค่านั้น (มากไปหาน้อย) และในการตรวจสอบลำดับ เพื่อดูว่าคุณสามารถสร้าง "แพ็คเกจ" ด้วยผลิตภัณฑ์ที่ไม่ใช่ผลิตภัณฑ์หลักที่เหลือด้วยแบบสอบถามและวนรอบกระบวนการจนกว่าจะไม่มีผลิตภัณฑ์หลักเพิ่มเติมหรือไม่มีผลิตภัณฑ์ที่ไม่ใช่ผลิตภัณฑ์หลักเพิ่มเติมในส่วนที่เหลือ