CodeGym/Java Course/All lectures for BN 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);

মজাদার! নাম পাওয়ার জন্য এসকিউএল ক্যোয়ারীটি টাস্কের বর্ণনার চেয়েও ছোট বলে প্রমাণিত হয়েছে। এসকিউএল-এর নির্মাতারা তাদের রুটি বৃথা খায়নি।

তোমাকে মন খারাপ করতে বাধ্য করেছি-এই পদ্ধতি কাজ করবে না. প্রথমে আপনাকে এই টেবিলগুলিতে যোগ দিতে হবে, এটি দেখতে এরকম কিছু হবে:

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;

চলুন এটা একটু কঠিন করা যাক. শুধুমাত্র ভাল কর্মচারীদের জন্য যাদের বেতন 50k-এর বেশি হবে তাদের জন্য আপনাকে 80-এ লেভেল সেট করতে হবে। সম্পূর্ণ সমাধান এই মত দেখাবে:

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;

এখন এটা নিয়ে বাঁচুন।

মন্তব্য
  • জনপ্রিয়
  • নতুন
  • পুরানো
মন্তব্য লেখার জন্য তোমাকে অবশ্যই সাইন ইন করতে হবে
এই পাতায় এখনও কোনো মন্তব্য নেই