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