কম্পিউটার

আমরা কিভাবে MySQL হ্যান্ডলার লিখতে পারি, একটি সংরক্ষিত পদ্ধতিতে, যেটি একটি ত্রুটি বার্তা ছুড়ে দেয় এবং কার্যকর করা চালিয়ে যায়?


যেহেতু আমরা জানি যে যখনই MySQL সঞ্চিত পদ্ধতিতে একটি ব্যতিক্রম ঘটেছে, সঠিক ত্রুটি বার্তা ছুঁড়ে এটি পরিচালনা করা খুবই গুরুত্বপূর্ণ কারণ যদি আমরা ব্যতিক্রমটি পরিচালনা না করি, তাহলে একটি সংরক্ষিত পদ্ধতিতে সেই নির্দিষ্ট ব্যতিক্রমের সাথে অ্যাপ্লিকেশন ব্যর্থ হওয়ার সুযোগ থাকবে। . MySQL একটি হ্যান্ডলার প্রদান করে যা একটি ত্রুটির বার্তা ছুড়ে দেয় এবং সম্পাদন চালিয়ে যায়। এটি প্রদর্শন করার জন্য, আমরা নিম্নলিখিত উদাহরণটি ব্যবহার করছি যেখানে আমরা একটি প্রাথমিক কী কলামে একটি ডুপ্লিকেট মান সন্নিবেশ করার চেষ্টা করছি৷

উদাহরণ

mysql> DELIMITER //
mysql> Create Procedure Insert_Studentdetails(S_Studentid INT, S_StudentName Varchar(20), S_Address Varchar(20))
   -> BEGIN
   -> DECLARE CONTINUE HANDLER FOR SQLEXCEPTION SELECT 'Got an error';
   -> INSERT INTO Student_detail
   -> (Studentid, StudentName, Address)
   -> Values(S_Studentid,S_StudentName,S_Address);
   -> Select * from Student_detail;
   -> END //
Query OK, 0 rows affected (0.19 sec)

উপরের পদ্ধতিটি চালু করুন এবং এটি একটি ত্রুটির বার্তা ছুড়ে দেবে 'একটি ত্রুটি পেয়েছে' এবং আমরা যদি 'ছাত্রদের' কলামে ডুপ্লিকেট মান ইনপুট করার চেষ্টা করি তাহলে এটি সম্পাদন চালিয়ে যাবে৷

mysql> Delimiter ;
mysql> CALL Insert_Studentdetails(100, 'Gaurav', 'Delhi');
+-----------+-------------+---------+
| Studentid | StudentName | address |
+-----------+-------------+---------+
| 100       | Gaurav      | Delhi   |
+-----------+-------------+---------+
1 row in set (0.11 sec)

Query OK, 0 rows affected (0.12 sec)

mysql> CALL Insert_Studentdetails(101, 'Raman', 'Shimla');
+-----------+-------------+---------+
| Studentid | StudentName | address |
+-----------+-------------+---------+
|       100 | Gaurav      | Delhi   |
|       101 | Raman       | Shimla  |
+-----------+-------------+---------+
2 rows in set (0.06 sec)

Query OK, 0 rows affected (0.12 sec)

mysql> CALL Insert_Studentdetails(101, 'Rahul', 'Jaipur');
+--------------+
| Got an error |
+--------------+
| Got an error |
+--------------+
1 row in set (0.03 sec)

+-----------+-------------+---------+
| Studentid | StudentName | address |
+-----------+-------------+---------+
|       100 | Gaurav      | Delhi   |
|       101 | Raman       | Shimla  |
+-----------+-------------+---------+
2 rows in set (0.04 sec)

Query OK, 0 rows affected (0.05 sec)

mysql> CALL Insert_Studentdetails(103, 'Rahul', 'Jaipur');
+-----------+-------------+---------+
| Studentid | StudentName | address |
+-----------+-------------+---------+
|      100  | Gaurav      | Delhi   |
|      101  | Raman       | Shimla  |
|      103  | Rahul       | Jaipur  |
+-----------+-------------+---------+
3 rows in set (0.08 sec)
Query OK, 0 rows affected (0.10 sec)

  1. ফ্যাক্টরিয়াল গণনা করার জন্য আমরা কিভাবে MySQL সঞ্চিত পদ্ধতি তৈরি করতে পারি?

  2. আমি কিভাবে একটি MySQL সঞ্চিত ফাংশন লিখতে পারি যা একটি প্রদত্ত সংখ্যার ফ্যাক্টরিয়াল গণনা করে?

  3. কিভাবে একটি MySQL সঞ্চিত ফাংশন লিখতে হয় যা একটি টেবিলের মান আপডেট করে?

  4. কিভাবে সংরক্ষিত পদ্ধতিতে IF ব্যবহার করবেন এবং MySQL এ নির্বাচন করবেন?