1. পরিচিতি
MySQL একটি জনপ্রিয় সম্পর্কমূলক ডাটাবেস ব্যবস্থাপনা সিস্টেম যা অনেক ওয়েব অ্যাপ্লিকেশন এবং ডাটাবেস সিস্টেমে ব্যাপকভাবে ব্যবহৃত হয়। এর ডাটা টাইপগুলির মধ্যে, INT টাইপটি সংখ্যাগত মানগুলি পরিচালনার জন্য সবচেয়ে সাধারণভাবে ব্যবহৃতগুলির একটি। এই নিবন্ধটি MySQL INT টাইপের একটি বিস্তারিত ব্যাখ্যা প্রদান করে। বিশেষ করে, আমরা INT টাইপ দ্বারা সমর্থিত সর্বোচ্চ মানগুলি এবং এটি কীভাবে দক্ষতার সাথে ব্যবহার করা যায় তা অন্বেষণ করব। এই নিবন্ধটি পড়ে, আপনি MySQL-এ INT টাইপটি সঠিকভাবে ব্যবহার করার জন্য প্রয়োজনীয় জ্ঞান অর্জন করবেন।
2. INT টাইপের মৌলিক স্পেসিফিকেশন
INT-এর সর্বোচ্চ এবং সর্বনিম্ন মান
MySQL INT টাইপটি ৪ বাইট (৩২ বিট) স্টোরেজ ব্যবহার করে, এবং এটি যে মানগুলি সংরক্ষণ করতে পারে তার পরিসর নিম্নরূপ:
- সাইনযুক্ত (SIGNED) :
- সর্বনিম্ন মান: -2,147,483,648
- সর্বোচ্চ মান: 2,147,483,647
- অসাইনযুক্ত (UNSIGNED) :
- সর্বনিম্ন মান: 0
- সর্বোচ্চ মান: 4,294,967,295
INT-এর স্টোরেজ সাইজ
INT টাইপটি সর্বদা ৪ বাইট স্টোরেজ ব্যবহার করে। এই সাইজটি সংরক্ষিত মানের উপর নির্বিশেষে স্থির থাকে। অতএব, যদি আপনার খুব বড় সংখ্যাগত পরিসর পরিচালনার প্রয়োজন না হয়, তাহলে ছোট ডাটা টাইপগুলি (যেমন, TINYINT বা SMALLINT) বিবেচনা করা আরও দক্ষ।
INT-এর ব্যবহারের ক্ষেত্র
INT টাইপটি নিম্নলিখিত পরিস্থিতিগুলিতে সাধারণত ব্যবহৃত হয়:
- অটো-ইনক্রিমেন্ট মান (যেমন, ব্যবহারকারী আইডি, অর্ডার নম্বর)
- গণনা বা পরিসংখ্যানগত প্রক্রিয়াকরণে ব্যবহৃত পূর্ণসংখ্যা ডাটা (যেমন, ইনভেন্টরি গণনা, ক্লিক গণনা)
- নির্দিষ্ট পরিসরের মধ্যে প্রতিনিধিত্বকৃত ডাটা (যেমন, বয়স বা পরীক্ষার স্কোর)
এই ব্যবহারের ক্ষেত্রগুলিতে, প্রয়োজনীয় সংখ্যাগত পরিসর এবং মেমরি দক্ষতা বিবেচনা করা গুরুত্বপূর্ণ।
3. INT(M)-এ M-এর অর্থ কী?
ডিসপ্লে প্রস্থ (M) কী?
MySQL-এ, INT(M)-এর M “ডিসপ্লে প্রস্থ” প্রতিনিধিত্ব করে। এটি ডাটাবেসে সংরক্ষিত প্রকৃত সংখ্যাগত মানকে প্রভাবিত করে না; পরিবর্তে, এটি মানটি প্রদর্শিত হলে কীভাবে ফরম্যাট করা হবে তা নির্দিষ্ট করে। উদাহরণস্বরূপ, যদি INT(5) হিসেবে সংজ্ঞায়িত করা হয়, তাহলে সংখ্যাটি ৫ অঙ্কের প্রস্থে প্রদর্শিত হবে।
তবে, ডিসপ্লে প্রস্থ M-এর অর্থ নিম্নলিখিত ক্ষেত্রে শুধুমাত্র থাকে:
- ZEROFILL অপশন সক্রিয় থাকলে
- উদাহরণ:
INT(5) ZEROFILLসহ, যদি মানটি123হয়, তাহলে এটি00123হিসেবে প্রদর্শিত হবে।
ZEROFILL সম্পর্কে গুরুত্বপূর্ণ নোট
ZEROFILL অপশন ব্যবহার করলে, নিম্নলিখিত বৈশিষ্ট্যগুলি প্রযোজ্য:
- বাম দিকে অগ্রগণ্য শূন্যগুলি স্বয়ংক্রিয়ভাবে যোগ করা হয়।
UNSIGNEDঅ্যাট্রিবিউটটি স্বয়ংক্রিয়ভাবে প্রয়োগ করা হয়।
অতএব, যদি আপনার ঋণাত্মক মান সংরক্ষণ করার প্রয়োজন হয়, তাহলে আপনি ZEROFILL ব্যবহার করতে পারবেন না।
সাধারণ ভুল বোঝাবুঝির সমাধান
অনেক শিক্ষানবিস ভুলভাবে বিশ্বাস করে যে M সর্বোচ্চ সংরক্ষণযোগ্য মান সীমাবদ্ধ করে। তবে, M শুধুমাত্র ডিসপ্লে ফরম্যাটিংকে প্রভাবিত করে এবং প্রকৃত সংরক্ষণ পরিসরের উপর কোনো প্রভাব ফেলে না।
4. অন্যান্য পূর্ণসংখ্যা টাইপের সাথে তুলনা
পূর্ণসংখ্যা ডাটা টাইপের প্রকারভেদ এবং তাদের পরিসর
MySQL নিম্নলিখিত পূর্ণসংখ্যা টাইপগুলি প্রদান করে:
| Type Name | Bytes | Signed Range | Unsigned Range |
|---|---|---|---|
| TINYINT | 1 byte | -128 to 127 | 0 to 255 |
| SMALLINT | 2 bytes | -32,768 to 32,767 | 0 to 65,535 |
| MEDIUMINT | 3 bytes | -8,388,608 to 8,388,607 | 0 to 16,777,215 |
| INT | 4 bytes | -2,147,483,648 to 2,147,483,647 | 0 to 4,294,967,295 |
| BIGINT | 8 bytes | -9,223,372,036,854,775,808 to 9,223,372,036,854,775,807 | 0 to 18,446,744,073,709,551,615 |
নির্বাচনের মানদণ্ড
ডাটাবেস ডিজাইনে উপযুক্ত ডাটা টাইপ নির্বাচন করার সময় নিম্নলিখিত নির্দেশিকাগুলি ব্যবহার করুন:
- যদি পরিসরটি ছোট হয়: মেমরি সাশ্রয়ের জন্য
TINYINTবাSMALLINTব্যবহার করুন। - যদি অত্যন্ত বড় পরিসর প্রয়োজন হয়:
BIGINTব্যবহার করুন। - যদি সাধারণ-উদ্দেশ্য ব্যবহার কাম্য হয়:
INTসাধারণত সর্বোত্তম।
5. MySQL 8.0.17 থেকে পরিবর্তন
ডিসপ্লে প্রস্থ (M)-এর অবমান্যকরণ
MySQL 8.0.17 থেকে শুরু করে, পূর্ণসংখ্যা টাইপের জন্য “ডিসপ্লে প্রস্থ (M)” অবমান্যকৃত হয়েছে। এই পরিবর্তনটি ZEROFILL অপশনের অবমান্যকরণের সাথে একসাথে চালু করা হয়েছে, এবং এটি ভবিষ্যতের MySQL সংস্করণে অপসারণ করা হতে পারে।
ডিসপ্লে প্রস্থ অবমান্যকরণের কারণগুলি নিম্নরূপ:
- ভুল বোঝাবুঝি সৃষ্টি করেছে:
- অনেক ব্যবহারকারী ভুলভাবে বুঝেছে যে
Mসর্বোচ্চ সংরক্ষণযোগ্য মান বা অঙ্কের সংখ্যাকে প্রভাবিত করে।
- সীমিত ব্যবহারিক ব্যবহার:
- যেহেতু
Mশুধুমাত্র ডিসপ্লে ফরম্যাটিং নিয়ন্ত্রণ করত, তাই এখন ফরম্যাটিং সাধারণত অ্যাপ্লিকেশন পক্ষে পরিচালিত হয়, যা এর প্রয়োজনীয়তা কমিয়ে দেয়।
ZEROFILL-এর অবমান্যকরণ
The ZEROFILL অপশনটি একই সংস্করণে অব্যবহৃত করা হয়েছে। যদিও ZEROFILL শূন্য দিয়ে সংখ্যার আগে প্যাডিং করার জন্য সুবিধাজনক ছিল, তবে এখন নিম্নলিখিত কারণগুলোর জন্য এটি আর সুপারিশ করা হয় না:
- ব্যাপক বিকল্প পদ্ধতি:
- শূন্য-প্যাডিং এখন অ্যাপ্লিকেশন বা UI স্তরে সহজে পরিচালনা করা যায়।
- বিভ্রান্তি এড়ানো:
ZEROFILLব্যবহার করার সময়UNSIGNEDঅ্যাট্রিবিউটের স্বয়ংক্রিয় প্রয়োগ নবীন ব্যবহারকারীদের জন্য বিভ্রান্তি সৃষ্টি করত।
অব্যবহারের সাথে মানিয়ে নেওয়ার উপায়
এই অব্যবহারের প্রতিক্রিয়ায়, ডেটাবেস ডিজাইনে নিম্নলিখিত পদ্ধতিগুলি বিবেচনা করুন:
- অ্যাপ্লিকেশন স্তরে ফরম্যাটিং পরিচালনা করুন:
- শূন্য-প্যাডিং এবং ফরম্যাটিং অ্যাপ্লিকেশন বা প্রেজেন্টেশন স্তরে সম্পাদন করুন।
- উদাহরণ: PHP বা JavaScript ব্যবহার করে শূন্য-প্যাডিং বাস্তবায়ন করুন।
- ডিসপ্লে প্রস্থের উপর নির্ভর না করা একটি ডিজাইন গ্রহণ করুন:
Mনির্দিষ্ট না করেINTটাইপ সংজ্ঞায়িত করুন এবং ডিসপ্লে ফরম্যাটিংয়ের পরিবর্তে ডেটা সঠিকতায় মনোযোগ দিন।
৬. ব্যবহারিক FAQ বিভাগ
প্রায়শই জিজ্ঞাসিত প্রশ্নাবলী
প্রশ্ন১. যদি আমি INT টাইপের সর্বোচ্চ মানের চেয়ে বড় একটি মান সংরক্ষণ করি তাহলে কী হয়?
উত্তর: MySQL-এ, INT টাইপের সীমার বাইরে কোনো মান সংরক্ষণ করার চেষ্টা করলে ত্রুটি ঘটবে। আপনাকে হয় সমর্থিত সীমার মধ্যে একটি মান নির্বাচন করতে হবে, অথবা বড় সীমা বিশিষ্ট কোনো ডেটা টাইপে (যেমন, BIGINT) পরিবর্তন করতে হবে।
প্রশ্ন২. INT এবং BIGINT এর মধ্যে পার্থক্য কী?
উত্তর: BIGINT টাইপ INT-এর তুলনায় দ্বিগুণ স্টোরেজ ব্যবহার করে (৮ বাইট) এবং অনেক বিস্তৃত সংখ্যাত্মক পরিসর প্রদান করে। উদাহরণস্বরূপ, BIGINT-এর স্বাক্ষরিত পরিসর ±9 কুইন্টিলিয়নের বেশি, যা খুব বড় ডেটাসেট পরিচালনার জন্য উপযুক্ত।
প্রশ্ন৩. ZEROFILL অব্যবহৃত হওয়ার পরে, শূন্য-প্যাডেড ডিসপ্লে কীভাবে বাস্তবায়ন করা উচিত?
উত্তর: শূন্য-প্যাডিং অ্যাপ্লিকেশন স্তরে পরিচালনা করা সুপারিশ করা হয়। উদাহরণস্বরূপ, PHP-তে আপনি str_pad() ফাংশন ব্যবহার করতে পারেন, এবং JavaScript-এ padStart() মেথড ব্যবহার করে শূন্য-প্যাডিং বাস্তবায়ন করতে পারেন।
প্রশ্ন৪. INT এবং অন্যান্য পূর্ণসংখ্যা টাইপের মধ্যে কীভাবে নির্বাচন করব?
উত্তর: ডেটার পরিসরের ভিত্তিতে টাইপ নির্বাচন করুন। ছোট সংখ্যামূলক মান (যেমন, বয়স বা স্কোর) TINYINT-এর জন্য উপযুক্ত, মাঝারি স্কেলের ডেটা (যেমন, ব্যবহারকারী আইডি) INT-এর জন্য উপযুক্ত, এবং খুব বড় মান (যেমন, আর্থিক লেনদেনের ডেটা) BIGINT-এর জন্য উপযুক্ত।
৭. উপসংহার
এই প্রবন্ধে, আমরা MySQL INT ডেটা টাইপের বিস্তারিত ব্যাখ্যা প্রদান করেছি। মূল বিষয়গুলো নিম্নরূপ:
INTটাইপের স্বাক্ষরিত ও অস্বাক্ষরিত সর্বোচ্চ ও সর্বনিম্ন মানের পার্থক্য বোঝা সঠিক ডেটা ডিজাইনের ভিত্তি গঠন করে।- অব্যবহৃত “ডিসপ্লে প্রস্থ (M)” এবং “ZEROFILL” অপশনগুলোর বিকল্প পদ্ধতি বোঝা এবং ভবিষ্যৎ MySQL আপডেটের সাথে মানিয়ে নিতে পারে এমন ডেটাবেস ডিজাইন করা গুরুত্বপূর্ণ।
- ডেটার বৈশিষ্ট্যের ভিত্তিতে উপযুক্ত পূর্ণসংখ্যা টাইপ নির্বাচন করে একটি কার্যকর এবং রক্ষণাবেক্ষণযোগ্য ডেটাবেস গঠন করুন।
MySQL ডেটাবেস ডিজাইনে INT টাইপের ব্যবহার অপ্টিমাইজ করতে এবং দক্ষতা আরও বাড়াতে এই প্রবন্ধকে রেফারেন্স হিসেবে ব্যবহার করুন।


