PL/SQL এ Constants এবং Bind Variables

PL/SQL এর বেসিক স্ট্রাকচার - পিএল/এসকিউএল (PL/SQL) - Database Tutorials

404

PL/SQL প্রোগ্রামিংয়ে Constants এবং Bind Variables অত্যন্ত গুরুত্বপূর্ণ উপাদান, যা কোডের কার্যকারিতা, নিরাপত্তা এবং পারফরম্যান্স উন্নত করতে সাহায্য করে।


১. Constants (কনস্ট্যান্টস)

PL/SQL এ Constant হলো এমন একটি ভেরিয়েবল যার মান একবার ডিক্লেয়ার করার পর আর পরিবর্তন করা যায় না। কনস্ট্যান্ট ব্যবহারের সুবিধা হল, আপনি যখন কোনো নির্দিষ্ট মানের জন্য একটি ভেরিয়েবল ব্যবহার করতে চান এবং সেই মান পরিবর্তন না করার জন্য সুরক্ষিত রাখতে চান, তখন কনস্ট্যান্ট ব্যবহার করবেন।

কনস্ট্যান্ট ঘোষণা করার নিয়ম:

কনস্ট্যান্ট ডিক্লেয়ার করতে CONSTANT কীওয়ার্ড ব্যবহার করা হয়। কনস্ট্যান্টের মান শুধুমাত্র ডিক্লেয়ার করার সময় সেট করা যাবে এবং পরে পরিবর্তন করা যাবে না।

সিনট্যাক্স:

constant_name CONSTANT datatype := value;

উদাহরণ:

DECLARE
   -- Declaring a constant with a specific value
   pi CONSTANT NUMBER := 3.14159;
   max_salary CONSTANT NUMBER := 100000;
BEGIN
   DBMS_OUTPUT.PUT_LINE('The value of pi is ' || pi);
   DBMS_OUTPUT.PUT_LINE('The maximum salary is ' || max_salary);
END;

এখানে,

  • pi কনস্ট্যান্টটি NUMBER টাইপের এবং এর মান 3.14159 নির্ধারিত হয়েছে। এটি একবার ইনিশিয়ালাইজ করার পর পরিবর্তন করা যাবে না।
  • max_salary কনস্ট্যান্টটি একটি নির্দিষ্ট বেতন সীমা 100000 হিসাবে নির্ধারণ করা হয়েছে।

কনস্ট্যান্ট ব্যবহার করার সুবিধা:

  • নিরাপত্তা: কনস্ট্যান্টের মান পরিবর্তন করার সম্ভাবনা থাকে না, তাই কোডের মধ্যে ত্রুটি হওয়ার সম্ভাবনা কমে যায়।
  • সহজ maintenance: একটি স্থির মান যদি বারবার কোডে ব্যবহৃত হয়, তবে এক জায়গায় কনস্ট্যান্ট হিসেবে সেট করলে পরবর্তীতে কোড সহজে রক্ষণাবেক্ষণ করা যায়।

২. Bind Variables (বাইন্ড ভেরিয়েবলস)

Bind Variables হলো এমন ভেরিয়েবল যা SQL ক্যুয়েরি বা PL/SQL ব্লকের বাইরে থেকে মান গ্রহণ করে এবং পরে সেই মান SQL কমান্ড বা PL/SQL প্রসেসের মধ্যে ব্যবহার করা হয়। এটি মূলত সিকুয়েল কমান্ডের এক ধরনের রেফারেন্স ভেরিয়েবল হিসেবে কাজ করে এবং ভেরিয়েবলকে SQL কোডে ইনপুট বা আউটপুট প্যারামিটার হিসেবে ব্যবহার করা হয়।

Bind variables ব্যবহার করার মাধ্যমে আপনি SQL ইনজেকশন আক্রমণ থেকে রক্ষা পেতে পারেন, কারণ SQL কোড এবং ডেটা আলাদা রাখা হয়, এবং কোডটি বেশি নিরাপদ এবং পারফরম্যান্ট হয়।

Bind Variables এর ব্যবহার:

Bind variables সাধারণত SQL স্টেটমেন্টের মধ্যে প্লেসহোল্ডার হিসেবে ব্যবহৃত হয়, এবং পরে তাদের মান ডাইনামিকভাবে সেট করা হয়।

উদাহরণ:

DECLARE
   v_employee_id NUMBER := 101;  -- Employee ID bind variable
   v_employee_name VARCHAR2(50);
BEGIN
   -- Using bind variable in SQL query
   SELECT employee_name INTO v_employee_name
   FROM employees
   WHERE employee_id = v_employee_id;

   DBMS_OUTPUT.PUT_LINE('Employee Name: ' || v_employee_name);
END;

এখানে,

  • v_employee_id একটি bind variable হিসাবে ব্যবহার করা হচ্ছে, যা 101 মান ধারণ করছে।
  • SELECT স্টেটমেন্টে v_employee_id ব্যবহার করা হচ্ছে, যাতে ডাইনামিকভাবে বিভিন্ন এমপ্লয়ি আইডি দিয়ে ফলাফল পাওয়া যায়।

Bind Variables এর সুবিধা:

  1. SQL Injection Prevention: SQL ইনজেকশন আক্রমণ থেকে রক্ষা পাওয়ার জন্য bind variables অত্যন্ত কার্যকর। যেহেতু SQL কোড এবং ডেটা আলাদা থাকে, আক্রমণকারীরা ডেটার সাথে SQL কোড মিশিয়ে আক্রমণ করতে পারে না।
  2. পারফরম্যান্স উন্নতি: যখন SQL কোড বারবার রান করা হয়, তখন bind variables ব্যবহার করলে ডাটাবেস ক্যাশিং সুবিধা পাওয়া যায়। একবার পার্স করা SQL স্টেটমেন্ট পরবর্তীতে ব্যবহার করতে পারলে কার্যক্ষমতা বৃদ্ধি পায়।
  3. নিরাপত্তা: প্লেসহোল্ডার ব্যবহারের মাধ্যমে কোডের মধ্যে কোনও ইনপুট ডেটা সরাসরি সংযোজন না করেই নিরাপত্তা নিশ্চিত করা যায়।

Bind Variables এর উদাহরণ:

DECLARE
   v_dept_id NUMBER := 30;
   v_avg_salary NUMBER;
BEGIN
   -- Using bind variable in a query to get the average salary
   SELECT AVG(salary) INTO v_avg_salary
   FROM employees
   WHERE department_id = v_dept_id;

   DBMS_OUTPUT.PUT_LINE('The average salary in department ' || v_dept_id || ' is ' || v_avg_salary);
END;

এখানে,

  • v_dept_id হলো একটি bind variable, যার মান 30 (department_id) ব্যবহার করা হচ্ছে employees টেবিলের ডেটার মধ্যে।
  • SQL স্টেটমেন্টে bind variable ব্যবহার করে ডিপার্টমেন্টের গড় বেতন বের করা হচ্ছে।

সারাংশ:

PL/SQL এ Constants এবং Bind Variables দুটি গুরুত্বপূর্ণ ধারণা, যা প্রোগ্রামটির নিরাপত্তা এবং পারফরম্যান্স উন্নত করতে সাহায্য করে।

  1. Constants: পরিবর্তনযোগ্য নয় এমন মান ধারণ করতে ব্যবহৃত হয়, যা কোডের ভুল এবং জটিলতা কমায়।
  2. Bind Variables: SQL স্টেটমেন্টের মধ্যে ডাইনামিকভাবে মান পাস করতে ব্যবহৃত হয়, যা কোডকে আরো নিরাপদ, পুনঃব্যবহারযোগ্য এবং পারফরম্যান্ট করে তোলে।

এছাড়া, Bind variables ব্যবহার করার মাধ্যমে SQL ইনজেকশন প্রতিরোধ করা সম্ভব এবং কোডের কার্যক্ষমতা উন্নত করা যায়।

Content added By
Promotion

Are you sure to start over?

Loading...