अगर आप ऐसा कर रहे हैं:
- ऑब्जेक्ट बनाएं या लोड करें
$o
। - असाइन करें
'12345'
विचाराधीन संपत्ति/स्तंभ के लिए। - सहेजें
$o
और MySQL को'1234'
. के मान को छोटा करने दें । - प्रॉपर्टी/कॉलम को
$o
में एक्सेस करें और'12345'
get प्राप्त करें वापस।
तब आप अपने डेटाबेस को चुपचाप अपने डेटा को प्रबंधित करने देने की समस्याओं में से एक देख रहे हैं।
सहेजना सफल होता है, आपके ऑब्जेक्ट को पता नहीं है कि MySQL ने डेटा को छोटा कर दिया है इसलिए यह '12345'
रखता है डेटाबेस से उस कॉलम को फिर से लोड करने के बजाय, और आपके हाथ में असंगत डेटा है।
यदि आप MySQL पर निर्भर हैं और चुपचाप अपना डेटा काट रहे हैं तो आपको शायद यह करना होगा:
- अपना ऑब्जेक्ट बनाएं/लोड करें।
- गुण अपडेट किए गए।
- ऑब्जेक्ट सेव करें।
- वस्तु के लिए अपना स्थानीय संदर्भ फेंक दें।
- यह सुनिश्चित करने के लिए डेटाबेस से इसे नए सिरे से लोड करें कि आपको वास्तविक . मिलता है मान।
मैं MySQL के अंदर साइलेंट ट्रंकेशन से बचने के लिए आपकी वस्तुओं में सख्त सत्यापन जोड़ने की सलाह दूंगा। सख्त मोड चालू करना इस समस्या से भी बचेंगे लेकिन फिर आपको अपनी सभी त्रुटि प्रबंधन और डेटा सत्यापन (जो वास्तव में एक बुरी बात नहीं होगी) की समीक्षा करने और कसने की आवश्यकता होगी।