Mysql
 sql >> डेटाबेस >  >> RDS >> Mysql

अजगर में mysql के साथ तैयार बयानों का उपयोग करना

पायथन में MySQL के साथ तैयार किए गए कथनों का उपयोग करना समझाया गया है जैसे http://zetcode.com/db/mysqlpython/ -- Prepared statements के लिए उस पृष्ठ में देखें ।

आपके मामले में, वह होगा, उदा:

sql = ('INSERT INTO {} (date, time, tag, power) VALUES '
       '(%s, %s, %s, %s)'.format(self.db_scan_table))

और बाद में, "लूप में" जैसा कि आप इसे डालते हैं:

self.cursor.execute(sql, (d, t, tag, power))

बिना किसी स्ट्रिंग स्वरूपण के -- MySQLdb मॉड्यूल आपकी ओर से भागों को तैयार और निष्पादित करता है (और अनावश्यक रूप से काम को दोहराने से बचने के लिए चीजों को कैश कर सकता है, आदि)।

आपके द्वारा उल्लिखित "लूप" की प्रकृति के आधार पर विचार करें कि यह संभव है कि .execute_many पर एक ही कॉल किया जाए। (दूसरे तर्क के रूप में टुपल्स के अनुक्रम के साथ) पूरे लूप की जगह ले सकता है (जब तक कि आपको डीबी में डेटा डालने से परे उस लूप के भीतर और अधिक प्रसंस्करण की आवश्यकता न हो)।

जोड़ा गया:आजकल एक बेहतर विकल्प mysql के अपने Connector/Python का उपयोग करना हो सकता है और स्पष्ट prepare=True .cursor() . में विकल्प फ़ैक्टरी -- देखें http://dev .mysql.com/doc/connector-python/en/connector-python-api-mysqlcursorprepared.html . यह आपको एक विशिष्ट कर्सर देता है जिस पर कथन तैयार किए जाते हैं ("उस mysql.com पृष्ठ के अनुसार, "PREPARE और EXECUTE का उपयोग करने से अधिक कुशल" बाइनरी प्रोटोकॉल के साथ) और दूसरा उन बयानों के लिए जो बेहतर तैयार नहीं हैं; "अंतर्निहित से स्पष्ट बेहतर है" है "द ज़ेन ऑफ़ पायथन" के सभी सिद्धांतों के बाद (import this उन सभी सिद्धांतों को पढ़ने के लिए एक इंटरैक्टिव प्रॉम्प्ट से)। mysqldb चीजों को परोक्ष रूप से करना (और ऐसा लगता है कि वर्तमान ओपन-सोर्स संस्करण नहीं . है तैयार बयानों का उपयोग करें) Connector/Python के रूप में उतना अच्छा आर्किटेक्चर नहीं हो सकता है अधिक स्पष्ट है।



  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. INSERT INTO में सुधार कैसे करें ... लॉकिंग व्यवहार का चयन करें

  2. SQL कॉलम में सबसे अधिक बार आने वाला मान ज्ञात करें

  3. MySQL में वैकल्पिक तालिका:मित्र या शत्रु?

  4. MySQL डीबी में पायथन मसालेदार वस्तुओं को सहेजना

  5. MySQL UTF8 को UTF8MB4 समस्याओं और प्रश्नों में माइग्रेट करना