CodeGym/Java Course/All lectures for MR purposes/टेबलमधील डेटा बदलणे

टेबलमधील डेटा बदलणे

उपलब्ध

4.1 SET स्टेटमेंट अपडेट करा

जर आपल्याला टेबलमधील विद्यमान रेकॉर्ड बदलण्याची आवश्यकता असेल तर यासाठी आम्ही ऑपरेटर वापरतो UPDATE.

एकीकडे, ऑपरेटर ऑपरेटर UPDATEसारखाच आहे INSERT, कारण आम्हाला स्तंभांसाठी नवीन मूल्ये निर्दिष्ट करणे आवश्यक आहे. आणि दुसरीकडे, ऑपरेटरवर SELECT, कारण ते आपल्याला डेटा गटांसह त्वरित कार्य करण्यास अनुमती देते.

महत्वाचे! ऑपरेटरचा उद्देश UPDATEडेटा टेबलच्या एका ओळीत बदलणे नाही, परंतु विशिष्ट अटी पूर्ण करणाऱ्या सर्व पंक्तींमध्ये बदलणे आहे. आणि आपण एक लहान चूक केल्यास, आपण टेबलमधील सर्व डेटा सहजपणे गमावू शकता.

विनंतीचे सामान्य दृश्य:

UPDATE table SET
  	column 1 = expression 1,
  	column 2 = expression 2,
  	column 3 = expression 3
WHERE condition;

चला एक प्रश्न लिहूया ज्यामुळे आमच्या सर्व कर्मचार्‍यांचा पगार 100 ने वाढेल. आमची क्वेरी अशी दिसेल:

UPDATE employee SET
  	salary = salary+100;

आणि आता ५० हजार पेक्षा कमी पगार असलेल्या प्रत्येकासाठी आम्ही त्यात २०% वाढ करू. विनंतीचे उदाहरण:

UPDATE employee SET
  	salary = salary*1.2
WHERE salary<50000;

आणि अर्थातच, आम्ही दिग्दर्शकाचा पगार 2 पट वाढवू, त्याच्याशिवाय ते कसे होईल:

UPDATE employee SET
  	salary = salary*2
WHERE id=4;

4.2 जटिल डेटा बदल परिस्थिती

तुम्ही एकाच वेळी अनेक सारण्यांमधला डेटा बदलण्याचे ठरवल्यास किंवा एका टेबलमधील डेटा बदलताना, तुम्हाला तो दुसर्‍या टेबलमधील डेटाने भरावा लागेल किंवा पहिला बदलण्याच्या प्रक्रियेत दुसर्‍या टेबलमधील डेटा वापरावा लागेल. मग आश्चर्य आमची वाट पाहत आहे.

कर्मचारी टेबलमध्ये अस्तित्वात असलेल्या वापरकर्ता टेबलमधील सर्व वापरकर्त्यांची पातळी बदलण्याचा प्रयत्न करूया. साधेपणासाठी, आम्ही नावाद्वारे वापरकर्त्यांचा योगायोग तपासू.

आम्हाला ही क्वेरी कशी लिहायची आहे:

UPDATE user SET
  	level = 80,
WHERE user . name IN ( list of names from employee table );

बरं, या क्वेरीमध्ये कर्मचारी टेबलमधील नावांची यादी जोडूया:

UPDATE user SET
  	level = 80,
WHERE user.name IN (select name from employee);

मनोरंजक! नावे मिळविण्यासाठी SQL क्वेरी कार्याच्या वर्णनापेक्षा अगदी लहान असल्याचे दिसून आले. एसक्यूएलच्या निर्मात्यांनी त्यांची भाकरी व्यर्थ खाल्ली नाही.

तुम्हाला अस्वस्थ करण्यास भाग पाडले -हा दृष्टिकोन काम करणार नाही. प्रथम आपल्याला या सारण्यांमध्ये सामील होणे आवश्यक आहे, ते असे काहीतरी दिसेल:

UPDATE table 1, table 2 SET
  	column 1 = expression 1,
  	column 2 = expression 2,
  	column 3 = expression 3
WHERE table 1.id = table 2.ref_id;

चला ते थोडे अधिक कठीण करूया. ज्यांचा पगार ५०k पेक्षा जास्त असेल अशा चांगल्या कर्मचाऱ्यांसाठी तुम्हाला ८० वर स्तर सेट करणे आवश्यक आहे. संपूर्ण समाधान असे दिसेल:

UPDATE user, good_employees SET
  	user.level = 80
WHERE user.name = good_employees.name;

सारण्यांचे असे जोडणे प्रत्यक्षात आहे INNER JOIN, जेणेकरून शेवटी फक्त दुसर्‍या सारणीमध्ये नावाशी जुळणारे वापरकर्तेच राहतील.

परंतु तरीही आम्हाला चांगले कर्मचारी निवडण्याची आवश्यकता आहे, म्हणून आणखी काही कोड जोडूया:

SELECT * FROM employee WHERE salary >= 50000

आणि आता आम्ही आमच्या अंतिम क्वेरीमध्ये हे सारणी बदलतो:

UPDATE user,
    (SELECT * FROM employee WHERE salary >= 50000) good_emps
SET
    user.level = 80
WHERE user.name = good_emps.name;

आता त्याच्याबरोबर जगा.

टिप्पण्या
  • लोकप्रिय
  • नवीन
  • जुने
टिप्पणी करण्यासाठी तुम्ही साईन इन केलेले असणे आवश्यक आहे
या पानावर अजून कोणत्याही टिप्पण्या नाहीत