आप अपने डिजाइन के बहुत करीब हैं, लेकिन वहां बिल्कुल नहीं हैं।
सबसे पहले, आपकी ईवेंट तालिका में आपके ईवेंट के लिए अभी भी उपलब्ध टिकटों की संख्या (जो कुछ भी आप चाहते हैं उसके अतिरिक्त) रखने की आवश्यकता है।
दूसरा, आपकी एस्क्रो तालिका में एक DATETIME कॉलम होना चाहिए जो यह दर्शाता हो कि एस्क्रो कब समाप्त होता है। जब भी टिकट एस्क्रो में जाते हैं तो आपको वह मान सेट करना होगा।
तीसरा, एस्क्रो में टिकट डालने के लेन-देन की जरूरत है
- इवेंट पंक्ति को लॉक करें।
- उपलब्ध टिकट कॉलम पढ़ें। (यदि पर्याप्त न हो तो निरस्त करें)
- एस्क्रो टेबल में एक पंक्ति डालें
- उपलब्ध टिकट कॉलम को घटाने के लिए इवेंट पंक्ति को अपडेट करें।
- इवेंट पंक्ति को अनलॉक करें।
चौथा, बिक्री को पूरा करने की कार्रवाई के लिए एस्क्रो पंक्ति को हटाना और एक बेची गई टिकट पंक्ति सम्मिलित करना आवश्यक है। यह कठिन नहीं है।
पांचवां, आपको एस्क्रो क्लीनअप ऑपरेशन की आवश्यकता है। इसके लिए उन सभी एस्क्रो पंक्तियों की तलाश करनी होगी जो समाप्त हो चुकी हैं (जिनकी अतीत में समाप्ति तिथि है) और प्रत्येक के लिए:
- संबंधित ईवेंट पंक्ति को लॉक करें।
- एस्क्रो टेबल से एस्क्रो टिकटों की संख्या पढ़ें
- एस्क्रो तालिका पंक्ति हटाएं।
- उपलब्ध टिकट कॉलम को बढ़ाने के लिए ईवेंट पंक्ति को अपडेट करें।
- इवेंट पंक्ति को अनलॉक करें।
चाल उपलब्ध . की संख्या रखने की है टिकटों का रखरखाव इस तरह से किया जाता है जो सही ढंग से इंटरलॉक किया गया हो, इसलिए उपयोगकर्ताओं के बीच दौड़ की स्थिति आपके ईवेंट की अधिक बिक्री नहीं करती है।