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

स्क्रैच से पायथन फ्लास्क और MySQL का उपयोग करके एक वेब ऐप बनाना:भाग 4

इस ट्यूटोरियल श्रृंखला के पिछले भाग में, हमने एक लॉग-इन उपयोगकर्ता के लिए एक इच्छा जोड़ने के लिए आवश्यक कार्यक्षमता को लागू किया था। हमने यह भी देखा कि उपयोगकर्ता द्वारा दर्ज की गई इच्छाओं को उपयोगकर्ता के होम पेज पर कैसे प्रदर्शित किया जाता है।

इस भाग में, हम उपयोगकर्ता द्वारा दर्ज की गई इच्छाओं को संपादित करने और हटाने की कार्यक्षमता को लागू करेंगे।

आरंभ करना

आइए GitHub से ट्यूटोरियल के पिछले भाग को क्लोन करके शुरू करें।

गिट क्लोन https://github.com/jay3dec/PythonFlaskMySQLApp_Part3.git

एक बार सोर्स कोड क्लोन हो जाने के बाद, प्रोजेक्ट डायरेक्टरी में नेविगेट करें और वेब सर्वर शुरू करें।

cd PythonFlaskMySQLApp_Part3python app.py

अपने ब्राउज़र को http://localhost:5002/ पर इंगित करें और आपके पास एप्लिकेशन चलना चाहिए।

इच्छा सूची का संपादन

चरण 1: संपादित करें आइकन प्रदर्शित करें

हम पहले से ही प्राप्त डेटा को हमारे HTML में jQuery का उपयोग करके बाध्य कर रहे हैं। हम उस कोड को संशोधित करेंगे और डेटा को बाइंड करना आसान बनाने के लिए jQuery टेम्प्लेट का उपयोग करेंगे। हम एक edit भी जोड़ेंगे इच्छा को अद्यतन करने का एक तरीका प्रदान करने के लिए हमारे HTML पर आइकन। userHome.htmlखोलें और jQuery टेम्पलेट्स का संदर्भ शामिल करें।

मौजूदा list-group निकालें div और इसे निम्न HTML कोड से बदलें:

UL . के अंदर कक्षा के साथ list-group हम अपने डेटा को बाध्य करेंगे। एक listTemplate परिभाषित करें जैसा कि HTML के मुख्य भाग में दिखाया गया है:

jQuery को संशोधित करें डेटा को listTemplate से बाइंड करने के लिए AJAX सफलता कॉलबैक ।

साथ ही, कुछ शैलियों को userHome.html . में शामिल करें :

 <शैली> .ट्रैश {रंग:आरजीबी (209, 91, 71); } .पैनल-बॉडी .चेकबॉक्स {डिस्प्ले:इनलाइन-ब्लॉक; मार्जिन:0px; } .सूची-समूह { मार्जिन-नीचे:0px; }

सभी परिवर्तन सहेजें और सर्वर को पुनरारंभ करें। अपने ब्राउज़र को http://localhost:5002 पर इंगित करें और एक मान्य ईमेल पते और पासवर्ड का उपयोग करके साइन इन करें। एक बार लॉग इन करने के बाद, आपको उपयोगकर्ता द्वारा बनाई गई इच्छाओं को देखने में सक्षम होना चाहिए।

चरण 2:पॉपअप संपादित करें प्रदर्शित करें

हम इच्छाओं को संपादित करने के लिए एक इंटरफ़ेस प्रदान करने के लिए पॉपअप दिखाने के लिए बूटस्ट्रैप का उपयोग करेंगे। userHome.html . में बूटस्ट्रैप का संदर्भ शामिल करें ।

एक बार संदर्भ शामिल हो जाने के बाद, निम्न HTML को userHome.html में जोड़ें ।


उपरोक्त HTML पॉपअप के रूप में काम करेगा। जब उपयोगकर्ता edit . पर क्लिक करता है पॉपअप दिखाएगा आइकन। हमने पहले ही विशेषताएँ जोड़ दी हैं data-target और data-toggle जो मोडल पॉपअप को ट्रिगर करेगा।

 

उपरोक्त परिवर्तनों को सहेजें और ऐप को पुनरारंभ करें। एप्लिकेशन में साइन इन करने के बाद, edit . पर क्लिक करें आइकन और आपको पॉपअप देखने में सक्षम होना चाहिए।

चरण 3:पॉपअप संपादित करें को पॉप्युलेट करें

जब उपयोगकर्ता संपादन आइकन पर क्लिक करता है, तो हम अपडेट पॉपअप को title . के साथ दिखाएंगे और description अद्यतन करने के लिए। आरंभ करने के लिए, उपयोगकर्ता द्वारा संपादन आइकन पर क्लिक करने के बाद, पहले हमें विशेष इच्छा विवरण प्राप्त करने के लिए इच्छा आईडी की आवश्यकता होती है। तो एक अतिरिक्त विशेषता data-id शामिल करने के लिए jQuery के टेम्पलेट कोड को संशोधित करें एंकर तत्व संपादित करें पर।


हमने एक onclick भी संलग्न किया है विधि को कॉल करने के लिए घटना edit . एडिट फंक्शन के अंदर, हम getWishById नामक एक पायथन मेथड के लिए AJAX कॉल करेंगे। जो इच्छा विवरण लौटाएगा।

फ़ंक्शन संपादित करें (एल्म) {$.ajax({url:'/getWishById', डेटा:{ id:$(elm).attr('data-id') }, टाइप करें:'POST', Success:function (रेस) { कंसोल.लॉग (रेस); }, त्रुटि:फ़ंक्शन (त्रुटि) { कंसोल.लॉग (त्रुटि); }});}

इसके बाद, app.pyखोलें और getWishById . नामक एक विधि बनाएं . इस पद्धति का उपयोग करके, हम डेटाबेस से विशेष इच्छा विवरण प्राप्त करेंगे।

@app.route('/getWishById',methods=['POST'])def getWishById():try:if session.get('user'):_id =request.form['id'] _user =session.get('user') conn =mysql.connect() कर्सर =conn.cursor() कर्सर.callproc('sp_GetWishById',(_id,_user)) result =कर्सर.fetchall() विश =[] विश.एपेंड ({'Id':result[0][0],'Title':result[0][1],'Description':result[0][2]}) return json.dumps (इच्छा) और:return render_template ('error.html', error ='Unauthorized Access') अपवाद को छोड़कर e:return render_template('error.html',error =str(e))

जैसा कि आप उपरोक्त विधि में देख सकते हैं, हमने इस विधि के लिए इच्छा आईडी में पास कर दिया है और यह user ID का उपयोग करके डेटाबेस से डेटा प्राप्त करता है और wish ID . एक बार डेटा प्राप्त हो जाने के बाद, यह उस डेटा को एक सूची में बदल देता है और फिर इसे JSON के रूप में वापस कर देता है डेटा।

इसके बाद, डेटाबेस से डेटा लाने के लिए आवश्यक MySQL संग्रहीत कार्यविधि बनाते हैं।

DELIMITER $$CREATE DEFINER=`root`@`localhost` PROCEDURE `sp_GetWishById`(IN p_wish_id bigint,in p_user_id bigint)BEGINtbl_wish से * चुनें जहां विश_आईडी =p_wish_id और Wish_user_id =p_user_id; 

ऊपर दिखाया गया कोड wish ID . का उपयोग करके विशेष इच्छा विवरण प्राप्त करने के लिए संग्रहीत प्रक्रिया है और user ID

परिवर्तनों को सहेजें और सर्वर को पुनरारंभ करें। एप्लिकेशन में साइन इन करने के बाद, edit . पर क्लिक करें आइकन और आपके ब्राउज़र कंसोल में विवरण लॉग इन होना चाहिए।

प्राप्त डेटा को HTML पॉपअप से बाँधने के लिए, पहले data-target को हटा दें और data-toggle संपादन आइकन एंकर टैग से विशेषताएँ। फिर निम्न कोड को edit में जोड़ें पॉपअप पॉप्युलेट करने और उसे ट्रिगर करने के लिए JavaScript फ़ंक्शन सफलता कॉलबैक।

// प्राप्त JSON stringvar डेटा को पार्स करें =JSON.parse(res);//पॉप्युलेट द पॉप अप$('#editTitle').val(data[0]['Title']);$('# EditDescription').val(data[0]['Description']);// ट्रिगर द पॉप अप$('#editModal').modal();

परिवर्तनों को सहेजें और सर्वर को पुनरारंभ करें। एप्लिकेशन में साइन इन करने के बाद, संपादन आइकन पर क्लिक करने का प्रयास करें और आपके पास शीर्षक और विवरण के साथ पॉपअप होना चाहिए।

चरण 4:इच्छा विवरण अपडेट करें

अद्यतन कार्यक्षमता को लागू करने के लिए, आइए पहले एक MySQL संग्रहीत कार्यविधि बनाएं।

DELIMITER $$CREATE DEFINER=`root`@`localhost` प्रक्रिया `sp_updateWish`(IN p_title varchar(45),IN p_description varchar(1000),IN p_wish_id bigint,in p_user_id bigint)BEGINअपडेट tbl_wish सेट इच्छा,_शीर्षक =p_title Wish_description =p_description जहाँ Wish_id =p_wish_id और Wish_user_id =p_user_id;END$$DELIMITER;

जैसा कि ऊपर संग्रहीत कार्यविधि में देखा गया है, हम संशोधित title . में पास करेंगे और description ID . के साथ इच्छा और उपयोगकर्ता डेटाबेस में विवरण अपडेट करने के लिए।

इसके बाद, चलिए एक नई विधि बनाते हैं जिसे updateWish . कहा जाता है विवरण अद्यतन करने के लिए। यह रहा updateWish विधि:

@app.route('/updateWish', Methods=['POST'])def updateWish():try:if session.get('user'):_user =session.get('user') _title =request.form['title'] _description =request.form['description'] _wish_id =request.form['id'] conn =mysql.connect() कर्सर =conn.cursor() कर्सर.callproc('sp_updateWish', (_title,_description,_wish_id,_user)) डेटा =कर्सर.fetchall() अगर लेन (डेटा) 0 है:conn.commit() रिटर्न json.dumps ({'status':'OK'}) और:रिटर्न json. dumps({'status':'ERROR'}) अपवाद को छोड़कर e:return json.dumps({'status':'Unauthorized access'}) अंत में:कर्सर.क्लोज़() conn.close()

जैसा कि उपरोक्त कोड में देखा गया है, एक वैध सत्र के लिए मान्य होने के बाद, हमने पोस्ट किए गए डेटा को एकत्र किया है और संग्रहीत प्रक्रिया को sp_updateWish कहा है। विवरण अपडेट करने के लिए।

updateWish . पर कॉल करने के लिए विधि, हमें Update . पर एक ईवेंट संलग्न करने की आवश्यकता है बटन क्लिक। तो, अपडेट बटन को नाम दें btnUpdate और एक onclick संलग्न करें घटना जैसा दिखाया गया है:

$('#btnUpdate').click(function() { $.ajax({url:'/updateWish', data:{ title:$('#editTitle').val(), विवरण:$( '#editDescription').val(), id:localStorage.getItem('editId') }, टाइप करें:'POST', Success:function(res) {$('#editModal').modal('hide'); // ग्रिड को फिर से भरें}, त्रुटि:फ़ंक्शन (त्रुटि) {कंसोल.लॉग (त्रुटि);}})});

जैसा कि उपरोक्त कोड में देखा गया है, हमने editId . एकत्र किया है localStorage . से , इसलिए edit . के अंदर फ़ंक्शन ID को सहेजें localStorage . में ।

localStorage.setItem('editId',$(elm).attr('data-id'));

getWish को पूरा करें AJAX एक फ़ंक्शन में कॉल करता है, ताकि डेटा अपडेट होने के बाद हम इसे फिर से कॉल कर सकें।

फ़ंक्शन GetWishes() { $.ajax({url:'/getWish', type:'GET', Success:function(res) { var WishObj =JSON.parse(res); $('#ulist') .खाली (); $('#listTemplate').tmpl(wishObj).appendTo('#ulist'); }, त्रुटि:फ़ंक्शन (त्रुटि) { कंसोल.लॉग (त्रुटि); }});}

GetWishes पर कॉल करें Update . की सफलता कॉलबैक में कार्य करें AJAX कॉल।

$('#btnUpdate').click(function() { $.ajax({url:'/updateWish', data:{ title:$('#editTitle').val(), विवरण:$( '#editDescription').val(), id:localStorage.getItem('editId') }, टाइप करें:'POST', Success:function(res) {$('#editModal').modal('hide'); // ग्रिड GetWishes (); }, त्रुटि:फ़ंक्शन (त्रुटि) {कंसोल.लॉग (त्रुटि); }})}) को फिर से भरें;

सभी परिवर्तन सहेजें और सर्वर को पुनरारंभ करें। एप्लिकेशन में साइन इन करने के बाद, उपयोगकर्ता द्वारा बनाई गई उपलब्ध इच्छाओं को संपादित करने का प्रयास करें।

इच्छा हटाना

चरण 1:एक पुष्टिकरण पॉपअप दिखाएं

userHome.html में निम्न HTML कोड जोड़ें ।


listTemplate . के अंदर एक डिलीट आइकन जोड़ें निम्नलिखित HTML जोड़कर:


उपरोक्त डिलीट आइकन पर क्लिक करने पर, हम ConfirmDelete . नामक एक JavaScript फ़ंक्शन को कॉल करेंगे जहां हम पुष्टिकरण पॉपअप को ट्रिगर करेंगे।

फ़ंक्शन कन्फर्मडिलेट (एलईएम) { localStorage.setItem('deleteId', $(elem).attr('data-id')); $('#deleteModal').modal();}

परिवर्तनों को सहेजें और सर्वर को पुनरारंभ करें। एक बार साइन इन करने के बाद, इच्छा सूची में हटाएं आइकन पर क्लिक करें और आपको पुष्टिकरण पॉपअप देखने में सक्षम होना चाहिए।

चरण 2:एक इच्छा हटाएं

डिलीट विश फंक्शनलिटी को लागू करने के लिए, सबसे पहले डिलीट करने के लिए MySQL स्टोर्ड प्रोसीजर बनाते हैं।

DELIMITER $$USE `BucketList`$$CREATE PROCEDURE `sp_deleteWish` (IN p_wish_id bigint,IN p_user_id bigint)BEGINtbl_wish से हटाएं जहां विश_आईडी =p_wish_id और Wish_user_id =p_user_id;END$$DELI 

उपरोक्त प्रक्रिया इच्छा आईडी और उपयोगकर्ता आईडी लेती है और डेटाबेस से संबंधित इच्छा को हटा देती है।

इसके बाद, app.py . के अंदर एक विधि बनाते हैं प्रक्रिया को कॉल करने के लिए sp_deleteWish .

हम deleteWish . नामक एक विधि बनाएंगे इच्छा हटाने के लिए।

@app.route('/deleteWish',methods=['POST'])def deleteWish():try:if session.get('user'):_id =request.form['id'] _user =session.get('user') conn =mysql.connect() कर्सर =conn.cursor() कर्सर.callproc('sp_deleteWish',(_id,_user)) result =कर्सर.fetchall() अगर लेन (परिणाम) 0 है :conn.commit() वापसी json.dumps ({'स्थिति':'ठीक'}) अन्य:वापसी json.dumps ({'स्थिति':'एक त्रुटि हुई'}) अन्य:वापसी render_template ('error.html') ,त्रुटि ='अनधिकृत एक्सेस') अपवाद को छोड़कर e:रिटर्न json.dumps({'status':str(e)}) अंत में:कर्सर.क्लोज़ () conn.close ()

उपरोक्त विधि में, हमने पहले सत्र को मान्य किया है। एक बार जब हम उपयोगकर्ता सत्र को सत्यापित कर लेते हैं, तो इच्छा आईडी और उपयोगकर्ता आईडी का उपयोग करके हमने संग्रहीत प्रक्रिया को sp_deleteWish कहा है ।

उपरोक्त विधि को कॉल करने के लिए deleteWish , एक onclickजोड़ें डिलीट कन्फर्मेशन पॉपअप में डिलीट बटन पर इवेंट।

Delete नामक JavaScript फ़ंक्शन बनाएं , और डिलीट के अंदर अजगर विधि के लिए एक AJAX कॉल करें deleteWish

फंक्शन डिलीट() { $.ajax({url:'/deleteWish', डेटा:{ id:localStorage.getItem('deleteId') }, टाइप करें:'POST', Success:function(res) { var result =JSON.parse(res); अगर (result.status =='OK') {$('#deleteModal').modal('hide'); GetWishes (); } और {अलर्ट (result.status); } }, त्रुटि:फ़ंक्शन (त्रुटि) { कंसोल.लॉग (त्रुटि); }});}

उपरोक्त की सफलता कॉलबैक पर Delete फ़ंक्शन, हम लौटाई गई स्थिति की जांच करेंगे, और यदि यह ठीक है तो हम मोडल पॉपअप को छिपा देंगे और इच्छाओं को पुनः लोड करेंगे।

परिवर्तनों को सहेजें और सर्वर को पुनरारंभ करें। एप्लिकेशन में लॉग इन करने के बाद, उपयोगकर्ता होम पेज से एक इच्छा को हटाने का प्रयास करें।


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Myd, .myi, .frm फ़ाइलों से MySQL डेटाबेस को कैसे पुनर्प्राप्त करें

  2. MySQL ट्रिगर्स का उपयोग करना

  3. डेटा के बिना MySQL निर्यात स्कीमा

  4. UTF-8 सभी तरह से

  5. MySQL एकाधिक तालिकाओं में सम्मिलित करें? (डेटाबेस सामान्यीकरण?)