database - MySQL Race Conditions -


क्या यह MySQL (InnoDB) के साथ एक दौड़ की स्थिति पैदा करता है:

  1. प्रारंभ करें

  2. रिकॉर्ड प्राप्त करने का प्रयास करें।

  3. यदि रिकॉर्ड मौजूद नहीं है, तो वापसी करें।

  4. यदि रिकॉर्ड मौजूद है, तो उसे हटा दें और एक लॉग प्रविष्टि जोड़ दें जो कह रहा है कि हटाया गया है।

  5. अंत हस्तांतरण (प्रतिबद्ध / रोलबैक)।

क्या दूसरी प्रक्रिया केवल 2b में हटाए जाने के कदम से पहले शुरू हो सकती है, रिकॉर्ड की उपस्थिति का पता लगा सकता है और उसके बाद दोनों ही प्रक्रिया लॉग में प्रवेश प्रविष्टियों को हटाते हैं?

क्या कोई सावधानियां हैं जिन्हें मुझे लेने की आवश्यकता है?

धन्यवाद।

चरण 2 पर 'अपडेट के लिए चयन करें' का उपयोग करें। केवल एक प्रक्रिया को पंक्ति पर लॉक प्राप्त करने में सक्षम हो जाएगा, इस प्रकार आपके द्वारा वर्णित परिदृश्य से बचने के लिए।


Comments

Popular posts from this blog

python - Overriding the save method in Django ModelForm -

html - CSS autoheight, but fit content to height of div -

qt - How to prevent QAudioInput from automatically boosting the master volume to 100%? -