- 1 1. ভূমিকা: কেন আপনাকে MySQL ডেটা টাইপ তালিকা বুঝতে হবে
- 2 2. ডেটা টাইপ কী, এবং “সঠিক টাইপ বেছে নেওয়া” কেন গুরুত্বপূর্ণ?
- 3 3. MySQL ডেটা টাইপ ক্যাটেগরি (ওভারভিউ তালিকা)
- 4 3.1 নিউমেরিক টাইপ
- 5 3.2 তারিখ ও সময় টাইপ
- 6 3.3 স্ট্রিং / বাইনারি টাইপ
- 7 3.4 JSON টাইপ
- 8 3.5 স্পেশিয়াল টাইপ
- 9 4. কীভাবে প্রতিটি ডেটা টাইপ নির্বাচন ও ব্যবহার করবেন (মূল সিদ্ধান্ত পয়েন্ট)
- 10 4.1 কীভাবে নিউমেরিক টাইপ নির্বাচন করবেন
- 11 ৪.২ তারিখ ও সময় টাইপ কীভাবে নির্বাচন করবেন
- 12 ৪.৩ স্ট্রিং টাইপ কীভাবে নির্বাচন করবেন
- 13 ৪.৪ JSON টাইপ কীভাবে নির্বাচন করবেন
- 14 ৪.৫ ENUM / SET টাইপ কীভাবে নির্বাচন করবেন
- 15 ৪.৬ Binary / BLOB টাইপ কীভাবে নির্বাচন করবেন
- 16 ৫. অনুশীলন: টেবিল ডিজাইন করার সময় “ডেটা টাইপ রেফারেন্স লিস্ট” কীভাবে ব্যবহার করবেন
- 17 ৫.১ ধাপ ১: কলামের “উদ্দেশ্য” এবং “প্রকৃতি” স্পষ্ট করুন
- 18 5.2 ধাপ ২: প্রয়োজনীয় সীমা এবং ফরম্যাট অনুমান করুন
- 19 5.3 ধাপ ৩: ডেটা ভলিউম এবং পারফরম্যান্স বিবেচনা করুন
- 20 5.4 ধাপ ৪: নমুনা ডেটা দিয়ে টাইপ যাচাই করুন
- 21 5.5 ধাপ ৫: স্কেলেবিলিটি এবং রক্ষণাবেক্ষণযোগ্যতা বিবেচনা করুন
- 22 5.6 ধাপ ৬: CREATE TABLE উদাহরণ (প্রায়োগিক নমুনা)
- 23 ৬. সাধারণ ভুল এবং সেগুলি কীভাবে এড়ানো যায়
- 24 ৬.১ অতিরিক্ত বড় ডেটা টাইপ ব্যবহার করা
- 25 6.2 দশমিক মানের জন্য FLOAT/DOUBLE ব্যবহার (নির্ভুলতা সমস্যাসমূহ)
- 26 6.3 অতিরিক্ত বড় VARCHAR কলাম
- 27 6.4 TEXT টাইপের অতিরিক্ত ব্যবহার
- 28 6.5 তারিখ/সময় টাইপ নির্বাচন করা, তাদের বৈশিষ্ট্য না জেনে
- 29 6.6 ENUM / SET অতিরিক্ত স্বাচ্ছন্দ্যে ব্যবহার
- 30 6.7 “সুবিধাজনক” বলে JSON-এ অতিরিক্ত ডেটা প্যাক করা
- 31 6.8 টাইপ পরিবর্তনের খরচ কম অনুমান করা
- 32 7. সারাংশ
- 33 8. FAQ
- 33.1 Q1. আমি কি INT না BIGINT ব্যবহার করব?
- 33.2 Q2. আমি কি VARCHAR না TEXT ব্যবহার করব?
- 33.3 Q3. টাকা সংরক্ষণের জন্য DOUBLE ব্যবহার করা ঠিক হবে কি?
- 33.4 Q4. আমি DATETIME এবং TIMESTAMP এর পার্থক্য বুঝতে পারছি না। কীভাবে বেছে নেব?
- 33.5 Q5. ENUM ব্যবহার করা নিরাপদ কি?
- 33.6 Q6. এখনই কি আমি শুধু JSON ব্যবহার করতে পারি?
- 33.7 Q7. VARCHAR এর সর্বোচ্চ দৈর্ঘ্য কীভাবে নির্ধারণ করব?
- 33.8 Q8. যদি আমি ভুল টাইপ বেছে নিই, পরে কি পরিবর্তন করতে পারি?
1. ভূমিকা: কেন আপনাকে MySQL ডেটা টাইপ তালিকা বুঝতে হবে
যখন আপনি টেবিল ডিজাইন করেন বা MySQL‑এর সঙ্গে অ্যাপ্লিকেশন ইন্টিগ্রেট করেন, সবচেয়ে সাধারণ প্রশ্নগুলোর একটি হল: “এই কলামের জন্য কোন ডেটা টাইপ ব্যবহার করব?”
এটি INT হবে? সত্যিই কি BIGINT দরকার? স্ট্রিংয়ের জন্য VARCHAR যথেষ্ট নাকি TEXT ভাল? এই পছন্দগুলো ছোট মনে হতে পারে, তবে এগুলোই সেই ভিত্তি গঠন করে যা পরে আপনার সিস্টেমকে প্রভাবিত করে।
যদি আপনি ডেটা টাইপ নির্বাচন কীভাবে করবেন তা কম বুঝে নেন, তবে আপনি প্রায়ই নিম্নলিখিত সমস্যার মুখোমুখি হবেন:
- আপনার ডেটা প্রত্যাশার চেয়ে দ্রুত বাড়লে স্টোরেজ জায়গা নষ্ট হয়
- ইনডেক্সের আকার বাড়ে এবং কুয়েরি পারফরম্যান্স ধীরে ধীরে হ্রাস পায়
- রেঞ্জের বাইরে মান বা ওভারফ্লো অপ্রত্যাশিত বাগ বা এক্সসেপশন সৃষ্টি করে
- পরে কলামের টাইপ পরিবর্তন করতে বাধ্য হন, যা বড়‑স্কেল মাইগ্রেশনকে ট্রিগার করে
অন্য কথায়, সিস্টেম্যাটিকভাবে MySQL ডেটা টাইপগুলো বুঝে প্রতিটি ব্যবহার কেসের জন্য সঠিকটি বেছে নেওয়া পারফরম্যান্স ও মেইনটেইনেবিলিটি উভয়ই দ্রুত উন্নত করার সর্বোত্তম উপায়।
এই পৃষ্ঠা মূলত নিম্নলিখিত পাঠকদের জন্য তৈরি করা হয়েছে:
- MySQL দিয়ে সিরিয়াস সিস্টেম ডেভেলপমেন্ট শুরু করতে যাওয়া ইঞ্জিনিয়াররা
- ব্যাকএন্ড / ইনফ্রাস্ট্রাকচার‑মুখী ইঞ্জিনিয়াররা যারা বিদ্যমান টেবিল ডিজাইন রিভিউ করতে চান
- ওয়েব ডেভেলপার ও প্রোগ্রামাররা যারা ব্যবহার কেস অনুযায়ী “সুপারিশকৃত টাইপ” চান
আমরা প্রথমে প্রধান MySQL ডেটা টাইপগুলোকে একটি ক্যাটেগরাইজড “তালিকা” হিসেবে সাজাব। তারপর আমরা কী টাইপগুলো—নিউমেরিক, স্ট্রিং, ডেট/টাইম, JSON, ENUM/SET—এর বৈশিষ্ট্য, সাধারণ ব্যবহার কেস এবং নির্বাচন টিপস ব্যাখ্যা করব। শেষমেশ, আমরা সাধারণ ডিজাইন মিস্টেকগুলো এবং সেগুলো কীভাবে এড়ানো যায় তা সংক্ষেপে উপস্থাপন করব, সঙ্গে একটি FAQ।
এটি শুধুমাত্র “শব্দের তালিকা” নয়। এটি ডিসিশন‑মেকিং গাইডেন্স হিসেবে গঠন করা হয়েছে যাতে আপনি বাস্তব প্রকল্পে টেবিল ডিজাইন করার সময় আটকে না যান। পরবর্তী সেকশনে, চলুন ডেটা টাইপ সম্পর্কে কীভাবে চিন্তা করতে হয় এবং ক্যাটেগরাইজড তালিকাটি রিভিউ করি।
2. ডেটা টাইপ কী, এবং “সঠিক টাইপ বেছে নেওয়া” কেন গুরুত্বপূর্ণ?
ডেটাবেসে, “ডেটা টাইপ” হল একটি নিয়ম যা নির্ধারণ করে একটি কলাম কোন ধরনের মান সংরক্ষণ করতে পারে।
MySQL অনেক ডেটা টাইপ সরবরাহ করে—ইন্টিজার, ডেসিমাল, স্ট্রিং, ডেট, বাইনারি, JSON ইত্যাদি—সুতরাং আপনার উদ্দেশ্যের উপর নির্ভর করে সঠিকভাবে বেছে নিতে হবে।
ডেটা টাইপের ভূমিকা
ডেটা টাইপ শুধুমাত্র “ফরম্যাট ক্যাটেগরি” নয়। এটি একসাথে একাধিক ভূমিকা পালন করে:
- ডেটার ধরন সীমাবদ্ধ করা (নিউমেরিক বনাম স্ট্রিং, বুলিয়ান ইত্যাদি)
- অনুমোদিত রেঞ্জ ও ডিজিটের সংখ্যা নির্ধারণ করা
- প্রয়োজনীয় মেমরি (স্টোরেজ সাইজ) নির্ধারণ করা
- ইনডেক্স স্ট্রাকচার ও সার্চ পারফরম্যান্সকে প্রভাবিত করা
- ইম্প্লিসিট কনভার্সন ও তুলনা নিয়মকে প্রভাবিত করা (যেমন, স্ট্রিং কলেশন)
সংক্ষেপে, ডেটা টাইপ শুধুমাত্র “কন্টেইনার” নয়—এগুলো মৌলিক ডিজাইন চয়েস যা পুরো ডেটা ম্যানেজমেন্ট লাইফসাইকেলকে প্রভাবিত করে।
ভুল টাইপ বেছে নিলে কী হয়?
যদি আপনি ভুল ডেটা টাইপ বেছে নেন, তবে বাস্তব কাজের মধ্যে নিম্নলিখিত সমস্যাগুলো প্রায়ই দেখা দেয়:
• স্টোরেজ নষ্ট হওয়া
উদাহরণস্বরূপ, যদি BIGINT (৮ বাইট) যথেষ্ট হয় কিন্তু আপনি ভুলবশত DECIMAL বা LONGTEXT ব্যবহার করেন, তবে প্রত্যাশার চেয়ে অনেক বেশি ডিস্ক স্পেস ব্যবহার করতে পারেন।
• ধীর কুয়েরি
বড় TEXT কলামে অতিরিক্ত LIKE সার্চ ব্যবহার করলে, অথবা অতিরিক্ত বড় নিউমেরিক টাইপ বেছে নিলে ইনডেক্সের আকার বাড়ে, ফলে SQL এক্সিকিউশন ধীর হয়ে যায়।
• অসঙ্গত মান বা ওভারফ্লো
INT-এ ফিট না হওয়া মান সংরক্ষণ করলে অপ্রত্যাশিত নেগেটিভ মান, রাউন্ডিং বা অন্যান্য সমস্যার সৃষ্টি হয়।
• উচ্চ‑খরচের টেবিল পরিবর্তন
বিশেষত বড় টেবিলে, ALTER TABLE দিয়ে টাইপ পরিবর্তন করলে নিম্নলিখিত সমস্যার মুখোমুখি হতে পারেন:
- দীর্ঘ লক সময়
- সার্ভিসে প্রভাব
- ডেটা মাইগ্রেশন কাজ ও অন্যান্য ঝুঁকি।
আগে থেকেই বুঝে নেওয়া উচিত মূল ক্যাটেগরিগুলো
MySQL ডেটা টাইপগুলোকে বৃহত্তরভাবে নিম্নলিখিত ক্যাটেগরিতে ভাগ করা যায়:
- নিউমেরিক টাইপ (ইন্টিজার, ডেসিমাল)
- স্ট্রিং টাইপ
- ডেট ও টাইম টাইপ
- বাইনারি টাইপ
- JSON টাইপ
- ENUM / SET টাইপ
- স্পেশিয়াল ডেটা টাইপ
Each category has different trade-offs—strengths/weaknesses, “light vs. heavy,” and “easy vs. hard to search.” That’s why you need the optimal type selection for each use case.
3. MySQL ডেটা টাইপ ক্যাটেগরি (ওভারভিউ তালিকা)
এই সেকশনে, আমরা MySQL‑এ উপলব্ধ ডেটা টাইপগুলোকে ক্যাটেগরাইজড ওভারভিউ তালিকা হিসেবে সংক্ষেপে উপস্থাপন করব। বাস্তবে, প্রথমে আপনি যে দুটি প্রশ্নের উত্তর চান তা হল “কোন কোন টাইপ আছে?” এবং “কোনটি ব্যবহার করা উচিত?”
সুতরাং এখানে আমরা ব্যবহার কেস, মূল বৈশিষ্ট্য, এবং প্রতিনিধিত্বমূলক টাইপ নাম স্পষ্টভাবে দেখাব, এবং পরবর্তী সেকশনে প্রতিটি ক্যাটেগরিকে আরও বিশদে ব্যাখ্যা করব।
3.1 নিউমেরিক টাইপ
নিউমেরিক টাইপগুলো সব ধরনের সংখ্যাসূচক প্রক্রিয়ার ভিত্তি, যার মধ্যে ইন্টিজার, ডেসিমাল, এবং ফ্লোটিং‑পয়েন্ট ভ্যালু অন্তর্ভুক্ত।
এই ক্যাটেগরি সবচেয়ে বেশি ব্যবহার হয় আইডি, পরিমাণ, দাম, ফ্ল্যাগ চেক, এবং আরও অনেক উদ্দেশ্যে।
ইন্টিজার টাইপ
| Type | Bytes | Characteristics / Use Cases |
|---|---|---|
| TINYINT | 1B | -128 to 127. Ideal for flags and small numbers |
| SMALLINT | 2B | -32,768 to 32,767. Lightweight integers |
| MEDIUMINT | 3B | Integer type that can handle a mid-range |
| INT / INTEGER | 4B | The most common integer type. Often used for IDs |
| BIGINT | 8B | Large values (order numbers, log counters, etc.) |
নোট
UNSIGNEDযোগ করলে পজিটিভ রেঞ্জ দ্বিগুণ হয়।INTঅনেক ক্ষেত্রে ব্যবহার হয়, তবেBIGINTঅযথা ব্যবহার করলে ইনডেক্স ভারী হয়ে যায়।
ডেসিমাল / ফ্লোটিং‑পয়েন্ট টাইপ
| Type | Characteristics |
|---|---|
| DECIMAL | Best for amounts like currency where errors are unacceptable |
| NUMERIC | Synonymous with DECIMAL |
| FLOAT | Memory-efficient, but may introduce rounding errors |
| DOUBLE | Higher precision than FLOAT, but errors can still occur |
নোট
- অর্থের জন্য,
DECIMALএকমাত্র যুক্তিসঙ্গত পছন্দ। ফ্লোটিং‑পয়েন্ট টাইপ (FLOAT/DOUBLE) ত্রুটি সৃষ্টি করতে পারে। - অনেক গণনা জড়িত ক্ষেত্রে, গতি/নির্ভুলতার ট্রেড‑অফের জন্য কখনো কখনো
DOUBLEবেছে নেওয়া হয়।
অন্যান্য নিউমেরিক টাইপ
| Type | Characteristics |
|---|---|
| BIT | Bit-level flag management (0/1) |
| BOOL / BOOLEAN | Actually an alias for TINYINT(1) |
3.2 তারিখ ও সময় টাইপ
তারিখ/সময় হ্যান্ডলিং অ্যাপ্লিকেশন ডেভেলপমেন্টে খুবই ঘন ঘন ব্যবহৃত হয়।
উদ্দেশ্যের উপর নির্ভর করে “টাইমজোন বিহেভিয়ার,” “অটো আপডেট,” এবং “সেকেন্ড‑লেভেল প্রিসিশন” ইত্যাদি ফ্যাক্টর ভিন্ন হয়, তাই সঠিক টাইপ নির্বাচন করা গুরুত্বপূর্ণ।
| Type | Characteristics / Use Cases |
|---|---|
| DATE | Date only (YYYY-MM-DD) |
| TIME | Time only (HH:MM:SS) |
| DATETIME | Date + time. Not affected by time zones |
| TIMESTAMP | Date + time. Stored as UNIX time; affected by time zones; can auto-update |
| YEAR | Stores the year only (YYYY) |
নোট
- যদি আপনি “updated at” স্বয়ংক্রিয়ভাবে ম্যানেজ করতে চান,
TIMESTAMPসুবিধাজনক। - “লগ” বা “হিস্ট্রি” যেখানে সঠিক টাইমস্ট্যাম্প সংরক্ষণ দরকার, সেখানে সাধারণত
DATETIMEব্যবহার হয়।
3.3 স্ট্রিং / বাইনারি টাইপ
ইউজারনেম, ইমেইল, পাসওয়ার্ড, বর্ণনা—স্ট্রিংগুলো টেবিল ডিজাইনের সবচেয়ে জটিল এলাকা হতে পারে।
ফিক্সড‑লেংথ স্ট্রিং
| Type | Characteristics |
|---|---|
| CHAR(n) | Always reserves space for exactly n characters. Suitable for fixed-length data (e.g., country codes) |
ভ্যারিয়েবল‑লেংথ স্ট্রিং
| Type | Characteristics |
|---|---|
| VARCHAR(n) | The most common string type. Best for data with varying length |
লার্জ টেক্সট (TEXT ফ্যামিলি)
| Type | Characteristics |
|---|---|
| TINYTEXT | Up to 255 characters |
| TEXT | Strings up to 64KB |
| MEDIUMTEXT | Up to 16MB |
| LONGTEXT | Up to 4GB |
নোট
- যদি আপনাকে আর্টিকেল বডি বা দীর্ঘ বর্ণনা মতো খুব বড় স্ট্রিং সংরক্ষণ করতে হয়,
TEXTব্যবহার করুন। - সার্চ এবং ইনডেক্স ডিজাইনে সতর্ক থাকুন।
বাইনারি ডেটা (BINARY / BLOB)
| Type | Characteristics |
|---|---|
| BINARY / VARBINARY | Fixed-length / variable-length binary data |
| BLOB / MEDIUMBLOB / LONGBLOB | Large binary data such as images and files |
※ সাধারণত, বড় ফাইলগুলো ডেটাবেসে সংরক্ষণ করা হয় না; সাধারণ ডিজাইন হল সেগুলোকে এক্সটার্নাল স্টোরেজে রাখা।
ENUM / SET টাইপ (এনুমারেশন)
| Type | Characteristics |
|---|---|
| ENUM | Select exactly one value from a predefined set of strings |
| SET | An enumeration type that allows selecting multiple values |
নোট
- যদি পরে টাইপ ডেফিনিশন পরিবর্তন করতে হয়, মেইনটেনেন্স ভারী হয়ে যায়।
- ছোট স্কেল, স্ট্যাটিক ক্যান্ডিডেটের জন্য এটি কার্যকর হতে পারে।
3.4 JSON টাইপ
| Type | Characteristics |
|---|---|
| JSON | Stores structured data. Officially supported since MySQL 5.7 |
- আপনি NoSQL‑সদৃশ ফ্লেক্সিবিলিটি পেতে পারেন, তবু JSON‑স্পেসিফিক ফাংশন ব্যবহার করতে পারেন।
- তবে, প্রায়ই সার্চ করা ডেটা JSON‑এ প্যাক করা সুপারিশ করা হয় না। যদি নরমালাইজ করা যায়, তবে তা স্ট্রাকচার্ড টেবিল হিসেবে মডেল করা উচিত।
3.5 স্পেশিয়াল টাইপ
এগুলো ভৌগোলিক ও লোকেশন ডেটা নিয়ে কাজ করার সময় ব্যবহার হয়।
| Type | Characteristics |
|---|---|
| GEOMETRY | Base type for spatial data |
| POINT, LINESTRING, POLYGON | Coordinates, lines, areas, and more |
সাধারণ ওয়েব অ্যাপ্লিকেশনে এগুলো কমই ব্যবহৃত হয়, তবে ম্যাপ অ্যাপ এবং GPS ইন্টিগ্রেশনের জন্য এগুলো গুরুত্বপূর্ণ।
4. কীভাবে প্রতিটি ডেটা টাইপ নির্বাচন ও ব্যবহার করবেন (মূল সিদ্ধান্ত পয়েন্ট)
এই সেকশনে, আমরা উপরে পরিচিত ক্যাটেগরিগুলোকে আরও গভীরভাবে বিশ্লেষণ করব, “বাস্তবিক দৃশ্যে কীভাবে নির্বাচন করবেন” উপর ফোকাস করে। শুধুমাত্র নাম জানলেই চলবে না—সর্বোত্তম ডেটা টাইপ নির্বাচন রক্ষণাবেক্ষণ, পারফরম্যান্স, এবং ভবিষ্যৎ স্কেলেবিলিটিতে বড় প্রভাব ফেলে।
4.1 কীভাবে নিউমেরিক টাইপ নির্বাচন করবেন
ইন্টিজার টাইপ নির্বাচন করার মানদণ্ড
ইন্টিজার টাইপ নির্বাচন করার সময়, নিম্নলিখিত তিনটি পয়েন্টে মনোযোগ দিন:
১. সর্বোচ্চ প্রয়োজনীয় রেঞ্জ বুঝুন
- ছোট কাউন্টার →
TINYINT - প্রোডাক্ট পরিমাণ / ফ্ল্যাগ →
SMALLINT/INT - বড় স্কেল আইডি বা লগ →
BIGINT
কিছু প্রকল্পে প্রাইমারি কী হিসেবে BIGINT অতিরিক্ত ব্যবহার করা হয়, যা ইনডেক্সের সাইজ বাড়িয়ে পারফরম্যান্সে নেতিবাচক প্রভাব ফেলতে পারে।
২. UNSIGNED সক্রিয়ভাবে বিবেচনা করুন
If you only handle positive values (e.g., numeric IDs, inventory counts)
→ using UNSIGNED doubles the range and may allow you to use a smaller type.
৩. টাকা বা নির্ভুলতা‑সংবেদনশীল মানের জন্য, DECIMAL ব্যবহার করুন
For values where “errors are not acceptable,” avoid FLOAT/DOUBLE and always use DECIMAL.
৪.২ তারিখ ও সময় টাইপ কীভাবে নির্বাচন করবেন
The appropriate type depends on your use case.
Differences Between DATETIME and TIMESTAMP
| Item | DATETIME | TIMESTAMP |
|---|---|---|
| Time zone | Not affected | Affected (converted) |
| Storage format | A “string-like” date/time | Stored as UNIX time |
| Auto update | Manual | Can auto-update (e.g., DEFAULT CURRENT_TIMESTAMP) |
| Range | Year 1000 to 9999 | Year 1970 to 2038 |
নির্বাচন করার সাধারণ নিয়ম
- অ্যাপ্লিকেশন লগ বা ইভেন্ট রেকর্ড →
DATETIME(টাইম জোন রূপান্তরের প্রভাব এড়াতে) - যখন আপনি স্বয়ংক্রিয়ভাবে আপডেটেড টাইমস্ট্যাম্প রেকর্ড করতে চান →
TIMESTAMP(সুবিধাজনক অটো‑আপডেট আচরণ)
যেখানে YEAR ব্যবহারযোগ্য
- আর্থিক‑বছরের বিভাগ, রিলিজ বছর, প্রতিষ্ঠার বছর ইত্যাদি → সংক্ষিপ্তভাবে পরিচালনা (১ বাইট)
৪.৩ স্ট্রিং টাইপ কীভাবে নির্বাচন করবেন
How to Decide Between CHAR and VARCHAR
কখন CHAR ব্যবহার করা উচিত
- দৈর্ঘ্য সর্বদা স্থির: প্রিফেকচার কোড, দেশ কোড, স্থির‑দৈর্ঘ্যের শনাক্তকারী ইত্যাদি।
- ডেটা যা দ্রুত অ্যাক্সেস প্রয়োজন এবং কমবার আপডেট হয়।
কখন VARCHAR ব্যবহার করা উচিত
- দৈর্ঘ্য পরিবর্তনশীল: নাম, ইমেইল ঠিকানা, শিরোনাম ইত্যাদি।
- অধিকাংশ পরিস্থিতিতে সেরা ডিফল্ট পছন্দ।
আপনি কি TEXT ব্যবহার করবেন?
Advantages of TEXT
- বড় টেক্সট সমর্থন করে (বর্ণনা, প্রবন্ধের মূল অংশ ইত্যাদি)।
Cautions for TEXT
- ইনডেক্সিং সীমিত (প্রিফিক্স ইনডেক্স প্রয়োজন)।
- JOIN বা WHERE ক্লজে ব্যবহার করলে পারফরম্যান্স হ্রাস পেতে পারে।
- অনুসন্ধান ও সাজানো ভারী হতে পারে।
প্রস্তাবনা:
বডি বা নোটের মতো “বড় স্ট্রিং” এর জন্য TEXT ব্যবহার করুন,
এবং অন্য সবকিছুর জন্য সম্ভব হলে VARCHAR ব্যবহার করুন।

৪.৪ JSON টাইপ কীভাবে নির্বাচন করবেন
The JSON type is very useful, but you need to use it “correctly.”
When JSON Works Well
- নমনীয় সেটিংস বা পরিবর্তনশীল সংখ্যক ফিল্ডের ডেটা।
- সীমিত লুকআপ ব্যবহার কেস, অথবা যখন অ্যাপ্লিকেশন এটি বিস্তৃত/পার্স করে।
- হালকা ডেটা সংরক্ষণ যা মাস্টার টেবিলের প্রয়োজন হয় না।
When JSON Is a Bad Fit
- আপনি যা ডেটা প্রায়ই অনুসন্ধান করেন।
- ফিল্টারড অনুসন্ধান, সমষ্টি, বা JOIN এর জন্য ব্যবহৃত ডেটা।
- গঠনমূলক ডেটা যা স্বাভাবিকীকরণ করা উচিত।
সাধারণ নিয়ম:
আপনাকে যেসব ডেটা অনুসন্ধান করতে হবে সেগুলি স্বাভাবিকীকরণ করা এবং গঠন হিসেবে বিবেচনা করা উচিত।
মনে রাখবেন JSON “নমনীয় কিন্তু অনুসন্ধানের জন্য দুর্বল”।
৪.৫ ENUM / SET টাইপ কীভাবে নির্বাচন করবেন
যখন ENUM উপযুক্ত
- অবস্থা স্থির: উদাহরণস্বরূপ, স্ট্যাটাস (
draft/published/archived)। - একটি ছোট বিকল্প সেট যা কমই পরিবর্তিত হয়।
ENUM ব্যবহারের সতর্কতা
- মান যোগ বা পরিবর্তন করতে
ALTER TABLEপ্রয়োজন। - অ্যাপ্লিকেশন‑সাইড সংজ্ঞার সাথে সামঞ্জস্য হারানোর ঝুঁকি।
যখন SET উপযুক্ত
- ছোট স্কেলের ডেটা যা একাধিক নির্বাচন প্রয়োজন (যেমন, উপলব্ধ সপ্তাহের দিন, অথবা যখন মাত্র কয়েকটি ট্যাগ অপশন থাকে)।
SET ব্যবহারের সতর্কতা
- মানের সমন্বয় জটিল হতে পারে।
- বহু‑মানের অবস্থা পরিচালনা কঠিন হতে পারে।
৪.৬ Binary / BLOB টাইপ কীভাবে নির্বাচন করবেন
BINARY / VARBINARY
- টোকেন, আইডি, হ্যাশ মান ইত্যাদি।
- স্থির‑দৈর্ঘ্যের বাইনারি (যেমন, ১৬‑বাইট UUID)।
BLOB টাইপের সাধারণ ব্যবহার কেস
- ছোট ফাইল, থাম্বনেইল ইমেজ, এনক্রিপ্টেড ডেটা।
তবে লক্ষ্য করুন
- ডেটাবেসে বড় ফাইল সংরক্ষণ করলে ব্যাকআপ ভারী হয়।
- রিড/রাইট লোডও বাড়ে → বাস্তব সিস্টেমে, এক্সটার্নাল স্টোরেজ + পাথ ম্যানেজমেন্টের সুপারিশ করা হয়।
৫. অনুশীলন: টেবিল ডিজাইন করার সময় “ডেটা টাইপ রেফারেন্স লিস্ট” কীভাবে ব্যবহার করবেন
এই অংশে, আমরা টেবিল ডিজাইন করার সময় প্র্যাকটিক্যাল ওয়ার্কফ্লোতে MySQL ডেটা টাইপ লিস্ট কীভাবে ব্যবহার করবেন তা ব্যাখ্যা করব।
শুধু টাইপ মুখস্থ করার বদলে, “আপনি কেন সেই টাইপ বেছে নিয়েছেন” লজিক ও ধাপের মাধ্যমে সংগঠিত করলে উচ্চমানের ডেটাবেস ডিজাইন হয়।
৫.১ ধাপ ১: কলামের “উদ্দেশ্য” এবং “প্রকৃতি” স্পষ্ট করুন
First, clearly define what will be stored in the column.
চেকলিস্ট
- এটি কি সংখ্যাসূচক, স্ট্রিং, তারিখ, নাকি ফ্ল্যাগ?
- এটি কি পরিবর্তনশীল দৈর্ঘ্যের নাকি স্থির দৈর্ঘ্যের?
- সর্বোচ্চ মান বা সর্বোচ্চ দৈর্ঘ্য কত?
- NULL অনুমোদন করা উচিত কি?
- ভবিষ্যতে এটি বৃদ্ধি পাবে কি না?
যদি আপনি এখানে অস্পষ্ট অনুমানের উপর এগিয়ে যান, তবে পরে টাইপ নির্বাচন অপ্রয়োজনীয়ভাবে জটিল হয়ে যায়।
5.2 ধাপ ২: প্রয়োজনীয় সীমা এবং ফরম্যাট অনুমান করুন
এরপর, আপনি যে মানগুলি সংরক্ষণ করবেন তার উচ্চ/নিম্ন সীমা, অক্ষরের দৈর্ঘ্য, এবং প্রয়োজনীয় নির্ভুলতা অনুমান করুন।
উদাহরণ: আইডি কলাম
- সর্বোচ্চ রেকর্ড সংখ্যা কি দশ মিলিয়ন, শত মিলিয়ন পর্যন্ত পৌঁছাবে? → এটি আপনাকে নির্ধারণে সাহায্য করে
INTযথেষ্ট হবে নাকিBIGINTপ্রয়োজন।
উদাহরণ: পণ্য নাম
- গড়ে ১৫–২৫ অক্ষর, সর্বোচ্চ প্রায় ৫০? →
VARCHAR(50)যথেষ্ট।TEXTঅপ্রয়োজনীয়।
উদাহরণ: মূল্য
- নির্ভুলতা প্রয়োজন কি? → আপনাকে
DECIMAL(10,2)এর মতো কিছু নির্বাচন করা উচিত।
5.3 ধাপ ৩: ডেটা ভলিউম এবং পারফরম্যান্স বিবেচনা করুন
MySQL ডেটা টাইপ নির্বাচন সরাসরি পারফরম্যান্সকে প্রভাবিত করে।
মূল বিবেচ্য বিষয়গুলো
- খুব বড় টাইপ → স্টোরেজ ব্যবহার করে এবং ইনডেক্সকে ভারী করে তোলে
TEXT/BLOB→ অনুসন্ধান পারফরম্যান্স হ্রাস করেJSON→ নমনীয় তবে অনুসন্ধানের জন্য দুর্বলTIMESTAMP→ স্বয়ংক্রিয় আপডেট এবং তুলনার জন্য কার্যকরী
বিশেষ করে, ইনডেক্সযুক্ত কলামগুলো সর্বোচ্চ হালকা ডেটা টাইপ ব্যবহার করা উচিত।
5.4 ধাপ ৪: নমুনা ডেটা দিয়ে টাইপ যাচাই করুন
টেবিল ডিজাইন করার পরে, দশক থেকে শতকোটি টেস্ট ডেটা রো ইনসার্ট করুন এবং আচরণ যাচাই করুন।
যাচাই করার বিষয়গুলো
- অনিচ্ছাকৃত রাউন্ডিং বা ট্রাঙ্কেশন সমস্যা আছে কি?
VARCHARযথেষ্ট নাকিTEXTহওয়া উচিত?- datetime সোর্টিং এবং সার্চিং প্রত্যাশিতভাবে কাজ করছে কি?
- JSON রিড/রাইট পারফরম্যান্স
বাস্তবিক ডেটা দিয়ে টেস্ট করা “তাত্ত্বিক ভুল ধারণা” কমিয়ে দেয়।
5.5 ধাপ ৫: স্কেলেবিলিটি এবং রক্ষণাবেক্ষণযোগ্যতা বিবেচনা করুন
টেবিল ডিজাইনের শেষ পর্যায়ে, ভবিষ্যতের পরিবর্তনগুলো সহজ হবে কিনা তা পরীক্ষা করুন।
ভারী টাইপ পরিবর্তনের উদাহরণগুলো
ENUM(মান যোগ করার সময়ALTER TABLEপ্রয়োজন)TEXT→VARCHAR(বড় করা সহজ, ছোট করা ঝুঁকিপূর্ণ)FLOAT→DECIMAL(সেমান্টিক্স পরিবর্তন করতে পারে)
ভবিষ্যতে সম্প্রসারণের সম্ভাবনা আছে কিনা তা বিবেচনা করে টাইপ নির্বাচন করুন।
5.6 ধাপ ৬: CREATE TABLE উদাহরণ (প্রায়োগিক নমুনা)
নিচে একটি উদাহরণ টেবিল দেওয়া হয়েছে যা একটি সাধারণ ওয়েব অ্যাপ্লিকেশনে ডেটা টাইপ নির্বাচন মানদণ্ডকে প্রতিফলিত করে।
CREATE TABLE products (
id BIGINT UNSIGNED AUTO_INCREMENT PRIMARY KEY,
name VARCHAR(100) NOT NULL,
price DECIMAL(10,2) NOT NULL,
stock INT UNSIGNED NOT NULL DEFAULT 0,
status ENUM('draft', 'published', 'archived') NOT NULL DEFAULT 'draft',
description TEXT,
created_at DATETIME NOT NULL,
updated_at TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP
);
এই উদাহরণে মূল পয়েন্টগুলো
- id : ভবিষ্যৎ স্কেল বিবেচনা করে
BIGINT UNSIGNEDব্যবহার করে - name : মাঝারি দৈর্ঘ্যের পরিবর্তনশীল স্ট্রিং →
VARCHAR - price : আর্থিক মান → সুনির্দিষ্ট
DECIMAL - stock : ইনভেন্টরি গণনা →
INT UNSIGNED - status : নির্দিষ্ট মানের সেট →
ENUM - description : সম্ভাব্য দীর্ঘ টেক্সট →
TEXT - updated_at : সুবিধাজনক স্বয়ংক্রিয় আপডেট
TIMESTAMP
যেমন দেখানো হয়েছে, প্রতিটি টাইপের পছন্দের স্পষ্ট যুক্তি থাকা উচিত, এবং সেই যুক্তি ব্যাখ্যা করা ভাল ডিজাইনের চিহ্ন।
৬. সাধারণ ভুল এবং সেগুলি কীভাবে এড়ানো যায়
MySQL অনেক ডেটা টাইপ সরবরাহ করে, তাই বাস্তব প্রকল্পে বেশ কিছু সাধারণ ভুল প্রায়ই দেখা যায়।
এই অংশে সাধারণ সমস্যাগুলো তুলে ধরা হয়েছে এবং ব্যবহারিক সমাধান প্রদান করা হয়েছে।
৬.১ অতিরিক্ত বড় ডেটা টাইপ ব্যবহার করা
সাধারণ উদাহরণগুলো
- সব আইডি
BIGINTকরা - প্রতিটি স্ট্রিংকে
VARCHAR(255)সেট করা - অ-টেক্সট কন্টেন্টের জন্য
TEXTব্যবহার করা
সমস্যাগুলো
- স্টোরেজের অপচয়
- বড় ইনডেক্স যা কুয়েরি পারফরম্যান্সকে ক্ষতিগ্রস্ত করে
- নেটওয়ার্ক ব্যান্ডউইথের অপচয় (বড় ডেটা ট্রান্সফার)
কীভাবে এড়ানো যায়
- সর্বোচ্চ ও সর্বনিম্ন মানগুলি আগে থেকেই অনুমান করুন
- প্রমাণের ভিত্তিতে
VARCHARদৈর্ঘ্য নির্ধারণ করুন - সত্যিই প্রয়োজন হলে মাত্র
TEXTব্যবহার করুন
6.2 দশমিক মানের জন্য FLOAT/DOUBLE ব্যবহার (নির্ভুলতা সমস্যাসমূহ)
সাধারণ উদাহরণ
FLOATহিসেবে দাম সংরক্ষণ- রাউন্ডিং ত্রুটির কারণে সংখ্যাগত তুলনা ব্যর্থ হয়
কিভাবে এড়ানো যায়
- অর্থ ও নির্ভুলতা‑গুরুত্বপূর্ণ মানের জন্য
DECIMALব্যবহার করুন - বৈজ্ঞানিক বা অস্থায়ী গণনা ছাড়া
FLOAT/DOUBLEব্যবহার এড়িয়ে চলুন
6.3 অতিরিক্ত বড় VARCHAR কলাম
সাধারণ উদাহরণ
- ডিফল্ট হিসেবে
VARCHAR(255)ব্যবহার করা - প্রায় ৩০ অক্ষর সংরক্ষণকারী কলামের জন্য বড় দৈর্ঘ্য নির্ধারণ করা
সমস্যাসমূহ
- মেমরি ও স্টোরেজের অপচয়
- ইনডেক্সগুলো প্রায়শই ভারী হয়ে যায়
কিভাবে এড়ানো যায়
- বাস্তব ডেটা থেকে গড় ও সর্বোচ্চ দৈর্ঘ্য অনুমান করুন
- অপ্রয়োজনীয়ভাবে বড় সাইজ এড়িয়ে চলুন (যেমন, ইমেইল ঠিকানা →
VARCHAR(100))
6.4 TEXT টাইপের অতিরিক্ত ব্যবহার
সাধারণ উদাহরণ
- “string = TEXT” ধরা
- ফিল্টারিং বা অনুসন্ধানের প্রয়োজনীয় ডেটার জন্য
TEXTব্যবহার করা
সমস্যাসমূহ
- ইনডেক্সিং সীমাবদ্ধতা অনেক
- ভারী
LIKEঅনুসন্ধান - JOIN-এ ধীর প্রক্রিয়াকরণ
কিভাবে এড়ানো যায়
- বর্ণনা বা বডির মতো দীর্ঘ ফর্মের কন্টেন্টের জন্য মাত্র
TEXTব্যবহার করুন - সম্ভব হলে অনুসন্ধানযোগ্য স্ট্রিংগুলো
VARCHAR-এ সংরক্ষণ করুন
6.5 তারিখ/সময় টাইপ নির্বাচন করা, তাদের বৈশিষ্ট্য না জেনে
সাধারণ উদাহরণ
- সবকিছুর জন্য
DATETIMEব্যবহার করা - “updated at” এর জন্য
DATETIMEব্যবহার করা, ফলে এটি স্বয়ংক্রিয়ভাবে আপডেট হয় না - টাইমজোন পার্থক্যের কারণে টাইমস্ট্যাম্প পরিবর্তিত হয়
কিভাবে এড়ানো যায়
- স্বয়ংক্রিয় আপডেট দরকার হলে:
TIMESTAMP - টাইমজোন শিফট এড়াতে:
DATETIME - শুধুমাত্র বছর দরকার হলে:
YEAR
6.6 ENUM / SET অতিরিক্ত স্বাচ্ছন্দ্যে ব্যবহার
সাধারণ উদাহরণ
- ভবিষ্যতে অপশন পরিবর্তন হতে পারে তবু
ENUMব্যবহার করা - কমা‑বিচ্ছিন্ন তালিকার মতো
SETব্যবহার করা
সমস্যাসমূহ
- পরিবর্তনের জন্য
ALTER TABLEপ্রয়োজন - অ্যাপ্লিকেশন‑সাইড সংজ্ঞার সাথে অসামঞ্জস্যতা বেশি সম্ভাবনা থাকে
কিভাবে এড়ানো যায়
- যদি মান বৃদ্ধি পেতে পারে, আলাদা মাস্টার টেবিলে পরিচালনা করুন
- সেটটি ছোট ও সত্যিই স্থির হলে মাত্র
ENUMব্যবহার করুন
6.7 “সুবিধাজনক” বলে JSON-এ অতিরিক্ত ডেটা প্যাক করা
সাধারণ উদাহরণ
- নরমালাইজ করা উচিত এমন কাঠামোকে JSON-এ প্যাক করা
- প্রায়ই অনুসন্ধান করা ডেটা JSON-এ সংরক্ষণ করা
সমস্যাসমূহ
- অনুসন্ধান পারফরম্যান্স হ্রাস পায়
- ইনডেক্স কম কার্যকর / ব্যবহার করা কঠিন হয়
- অ্যাপ্লিকেশন সাইডে পার্সিং কাজ বাড়ে
- স্কিমা‑বিহীন ডিজাইন সামঞ্জস্যতা ভাঙা সহজ করে দেয়
কিভাবে এড়ানো যায়
- যে ডেটা আপনি অনুসন্ধান করেন না তার জন্যই JSON ব্যবহার করুন
- সেটিংসের মতো “ছোট, পরিবর্তনশীল ডেটা” তে সীমাবদ্ধ রাখুন
- JOIN ও অনুসন্ধানের জন্য ব্যবহৃত তথ্য নরমালাইজ করুন
6.8 টাইপ পরিবর্তনের খরচ কম অনুমান করা
সমস্যাসমূহ
- বড় টেবিলে
ALTER TABLEঅত্যন্ত ভারী হতে পারে - সার্ভিস ডাউনটাইম বা দীর্ঘ লক সময় হতে পারে
- কিছু ক্ষেত্রে ডেটা মাইগ্রেশন প্রয়োজন হয়
কিভাবে এড়ানো যায়
- ডিজাইন পর্যায়ে ভবিষ্যৎ বৃদ্ধির জন্য পরিকল্পনা করুন
ENUMসতর্কতার সাথে ব্যবহার করুনDECIMAL-এর নির্ভুলতা/স্কেল-এ কিছু জায়গা রাখুন (কিন্তু অতিরিক্ত করবেন না)
7. সারাংশ
MySQL বিভিন্ন ধরনের ডেটা টাইপ সরবরাহ করে, এবং আপনি যে টাইপটি বাছাই করবেন তা পারফরম্যান্স, স্কেলেবিলিটি এবং রক্ষণাবেক্ষণযোগ্যতা-তে উল্লেখযোগ্য প্রভাব ফেলতে পারে।
বিশেষ করে ওয়েব অ্যাপ্লিকেশনের মতো পরিবেশে যেখানে ডেটা বৃদ্ধি পায়, প্রাথমিক ডিজাইন সিদ্ধান্তগুলি দীর্ঘমেয়াদী গুণমানকে সরাসরি প্রভাবিত করে।
এই প্রবন্ধের মূল বিষয়বস্তু
- ডেটা টাইপগুলি “মানের ধরন, পরিসর, নির্ভুলতা, স্টোরেজ এবং পারফরম্যান্স” প্রভাবিত করার গুরুত্বপূর্ণ উপাদান।
- সংখ্যাগত, স্ট্রিং, তারিখ/সময়, JSON, ENUM/SET এবং BLOB টাইপের প্রত্যেকেরই শক্তি ও দুর্বলতা আছে।
- ইন্টিজার, স্ট্রিং এবং তারিখ/সময় টাইপ সর্বাধিক ব্যবহৃত হয়, তাই সঠিকভাবে বাছাই করা গুরুত্বপূর্ণ।
- JSON এবং ENUM সুবিধাজনক, তবে ভুল ব্যবহার রক্ষণাবেক্ষণকে কঠিন করে তুলতে পারে।
TEXTএবংBLOBঅতিরিক্ত ব্যবহার পারফরম্যান্স হ্রাস করতে পারে।- একটি যুক্তিসঙ্গত ডিজাইন পদ্ধতি হল: “উদ্দেশ্য → পরিসর → পারফরম্যান্স → স্কেলেবিলিটি।”
আজই ব্যবহার করতে পারেন এমন একটি ডিজাইন চেকলিস্ট
- কলামের উদ্দেশ্য স্পষ্টভাবে সংজ্ঞায়িত হয়েছে কি?
- আপনি সর্বোচ্চ এবং সর্বনিম্ন সম্ভাব্য মানগুলো বুঝতে পারছেন কি?
- নির্বাচিত
VARCHARদৈর্ঘ্যের পেছনে কোনো প্রমাণ আছে কি? - আপনি টাকা সংরক্ষণের জন্য
DECIMALব্যবহার করছেন কি? - “updated at” টাইমস্ট্যাম্পগুলো
TIMESTAMPদিয়ে এবং প্রয়োজনীয় ক্ষেত্রে অটো-আপডেট দিয়ে পরিচালিত হচ্ছে কি? ENUMব্যবহার করার আগে, আপনি কি ভবিষ্যতে মানগুলো বাড়তে পারে কিনা বিবেচনা করেছেন?- আপনি কি অতিরিক্ত JSON ব্যবহার করে অনুসন্ধান ধীর হয়ে যাওয়া ডিজাইন এড়িয়ে চলছেন?
- আপনি কি বড় ডেটাসেটের উপর ভারী
ALTER TABLEঅপারেশন এড়াতে ডিজাইন করেছেন?
শেষ পর্যন্ত
MySQL ডেটা টাইপ বাছাই করার জন্য সবসময় একটি একক “সঠিক উত্তর” থাকে না।
তবে, যদি আপনি উদ্দেশ্যপূর্ণভাবে এবং ভবিষ্যৎ বৃদ্ধিকে মাথায় রেখে বাছাই করেন, তবে আপনি বড় সমস্যাগুলো প্রতিরোধ করতে পারেন এবং আপনার ডেটা কাঠামোকে পরিষ্কার রাখতে পারেন।
অবশেষে, সর্বোত্তম পছন্দ আপনার প্রকল্পের প্রকৃতি, ডেটার পরিমাণ এবং অ্যাপ্লিকেশনের প্রয়োজনীয়তার উপর নির্ভর করে। তবে যদি আপনি এই প্রবন্ধে উপস্থাপিত মানদণ্ডকে আপনার ভিত্তি হিসেবে ব্যবহার করেন, তবে আপনি যেকোনো পরিস্থিতিতে আরও ভাল ডেটা টাইপ বাছাই করতে সক্ষম হবেন।
পরবর্তীতে, আমরা একটি FAQ বিভাগ উপস্থাপন করব যা বাস্তব কাজের সময় প্রায়শই জিজ্ঞাসিত প্রশ্নগুলোকে সংক্ষেপে উপস্থাপন করে। টাইপ নির্বাচন নিয়ে অনিশ্চিত হলে, প্রথমে এই FAQ চেক করলে আপনার সিদ্ধান্ত গ্রহণ সহজ হবে।
8. FAQ
MySQL ডেটা টাইপ বাছাই করা এমন একটি ক্ষেত্র যেখানে বাস্তব অভিজ্ঞতার ওপর নির্ভর করে সিদ্ধান্তগুলো উল্লেখযোগ্যভাবে ভিন্ন হতে পারে। এখানে আমরা ডেভেলপমেন্ট টিমের সাধারণ প্রশ্নগুলো সংগ্রহ করে সংক্ষিপ্ত ও স্পষ্ট উত্তর প্রদান করছি।
Q1. আমি কি INT না BIGINT ব্যবহার করব?
উত্তর: ডিফল্টভাবে INT ব্যবহার করুন। ভবিষ্যতে যদি ২.১ বিলিয়নের বেশি হতে পারে তবে শুধুমাত্র BIGINT ব্যবহার করুন।
INT (৪ বাইট) প্রায় ২.১ বিলিয়ন পর্যন্ত সমর্থন করে এবং বেশিরভাগ অ্যাপ্লিকেশনের জন্য যথেষ্ট। লগ, উচ্চ ট্র্যাফিক সেবা, অথবা এমন সিস্টেম যেখানে বিপুল সংখ্যক আইডি জারি হতে পারে, সেক্ষেত্রে BIGINT বিবেচনা করুন।
Q2. আমি কি VARCHAR না TEXT ব্যবহার করব?
উত্তর: যদি অনুসন্ধান প্রয়োজন হয় তবে VARCHAR ব্যবহার করুন। দীর্ঘ ফর্মের কন্টেন্টের জন্য TEXT ব্যবহার করুন।
VARCHAR: ইনডেক্স‑বন্ধুত্বপূর্ণ এবং অনুসন্ধানের জন্য ভালTEXT: দীর্ঘ কন্টেন্টের জন্য ভাল তবে অনুসন্ধান বা JOIN এর জন্য আদর্শ নয়
※ অতিরিক্ত TEXT ব্যবহার পারফরম্যান্স হ্রাসের কারণ হতে পারে।
Q3. টাকা সংরক্ষণের জন্য DOUBLE ব্যবহার করা ঠিক হবে কি?
উত্তর: না। সর্বদা DECIMAL ব্যবহার করুন।
DOUBLE এবং FLOAT রাউন্ডিং ত্রুটি সৃষ্টি করতে পারে, তাই এগুলো টাকা বা নির্ভুলতা‑গুরুত্বপূর্ণ মানের জন্য উপযুক্ত নয়। ব্যবসায়িক সিস্টেমে, DECIMAL(10,2) অথবা DECIMAL(12,2) সাধারণ মানদণ্ড।
Q4. আমি DATETIME এবং TIMESTAMP এর পার্থক্য বুঝতে পারছি না। কীভাবে বেছে নেব?
উত্তর: যদি অটো‑আপডেট দরকার হয় তবে TIMESTAMP ব্যবহার করুন। যদি সময় অঞ্চল রূপান্তর ছাড়া সঠিক টাইমস্ট্যাম্প সংরক্ষণ করতে হয় তবে DATETIME ব্যবহার করুন।
TIMESTAMP: অটো‑আপডেট এবং সময় অঞ্চল রূপান্তরDATETIME: সময় অঞ্চলের দ্বারা প্রভাবিত হয় না; তারিখ/সময় “যেমন আছে” তেমনই সংরক্ষণ করে
DATETIME প্রায়ই লগ এবং ইতিহাস টেবিলের জন্য ব্যবহার করা হয়।
Q5. ENUM ব্যবহার করা নিরাপদ কি?
উত্তর: এটি কেবল তখনই উপযোগী যখন মানগুলো “পরিবর্তন না করার গ্যারান্টি” থাকে।
ENUM হালকা এবং সুবিধাজনক, তবে মান যোগ বা পরিবর্তন করতে ALTER TABLE প্রয়োজন। যদি ফিল্ডগুলো ভবিষ্যতে বাড়তে পারে, তবে একটি আলাদা টেবিলে মাস্টার ম্যানেজমেন্ট করার পরামর্শ দেওয়া হয়।
Q6. এখনই কি আমি শুধু JSON ব্যবহার করতে পারি?
উত্তর: আপনি যে ডেটা অনুসন্ধান করেন না তার জন্যই JSON ব্যবহার করুন। যেসব ডেটা অনুসন্ধান করা হয় সেগুলো নরমালাইজ করা উচিত।
JSON নমনীয়, তবে এর পারফরম্যান্স দুর্বলতা রয়েছে।
- অনুসন্ধানের জন্য দুর্বল
- ইনডেক্স কাঠামো আরও জটিল হয়ে যায়
- ডেটা সামঞ্জস্য বজায় রাখা কঠিন হয়
এটি সেটিংস এবং অপশনগুলোর জন্য ভাল কাজ করে—যেসব অ্যাট্রিবিউট অনুসন্ধান শর্ত হিসেবে ব্যবহার হয় না।
Q7. VARCHAR এর সর্বোচ্চ দৈর্ঘ্য কীভাবে নির্ধারণ করব?
উত্তর: বাস্তব ডেটার ভিত্তিতে সর্বোচ্চ অনুমান করুন এবং সামান্য বাফার যোগ করুন।
উদাহরণ: ইমেইল ঠিকানা → VARCHAR(100) যথেষ্ট
উদাহরণ: ইউজারনেম → VARCHAR(50) প্রায়ই যথেষ্ট
“শুধু ২৫৫” ব্যবহার করা সুপারিশ করা হয় না।
Q8. যদি আমি ভুল টাইপ বেছে নিই, পরে কি পরিবর্তন করতে পারি?
উত্তর: হ্যাঁ, তবে বড় টেবিলে এটি খুব ভারী হতে পারে।
ALTER TABLE প্রায়ই পুরো স্ক্যান এবং রিবিল্ড জড়িত করে, যা ডাউনটাইম বা দীর্ঘ লক সময়ের কারণ হতে পারে।
→ প্রাথমিক নকশা পর্যায়ে সতর্ক পরিকল্পনা সবচেয়ে গুরুত্বপূর্ণ.

