انواع داده (Data Types)
در MySQL، «انواع داده (Data Types)» مشخص می کنند هر ستون چه چیزی نگه دارد. این یعنی متن، عدد، پول، تاریخ و زمان، یا باینری. انتخاب درست نوع داده، کارایی و درستی اطلاعات را بهتر می کند.
سه خانواده اصلی در MySQL 8.0
هر ستون نام و نوع داده دارد. هنگام ساخت جدول، باید نوع داده مناسب را انتخاب کنیم. در MySQL سه گروه اصلی داریم: رشته ای، عددی، و تاریخ/زمان.
رشته ای (String)
برای متن ها از CHAR و VARCHAR استفاده می شود. CHAR طول ثابت دارد؛ VARCHAR طول متغیر. برای متن های بلندتر از TEXT و برای داده باینری از BLOBها استفاده می شود. ENUM فقط یک مقدار از لیست می پذیرد. SET صفر تا چند مقدار از لیست را نگه می دارد.
عددی (Numeric)
برای اعداد کوچک و بزرگ، از TINYINT تا BIGINT داریم. برای اعشاری ها از FLOAT، DOUBLE و DECIMAL استفاده می شود. DECIMAL دقت ثابت و دقیق برای مالی دارد. همه انواع عددی می توانند UNSIGNED یا ZEROFILL داشته باشند.
نکته: UNSIGNED اعداد منفی را ممنوع می کند. ZEROFILL نمایش را با صفر پر می کند و به صورت خودکار UNSIGNED را هم فعال می کند.
تاریخ و زمان (Date & Time)
برای تاریخ تنها از DATE استفاده کنید. برای تاریخ و زمان ترکیبی، DATETIME و TIMESTAMP موجود است. TIMESTAMP بر پایه ثانیه های یونیکس است و بازه مشخصی دارد. برای زمان تنها از TIME، و برای سال از YEAR استفاده می شود.
راهنمای انتخاب سریع
متن کوتاه؟ CHAR یا VARCHAR. متن خیلی بلند؟ TEXT. فایل/باینری؟ BLOB. شمارنده دقیق مالی؟ DECIMAL. عدد صحیح بزرگ؟ BIGINT. نیاز به تاریخ و زمان؟ DATETIME یا TIMESTAMP.
جمع بندی سریع
- نوع داده، محدوده مجاز ستون را تعیین می کند.
- سه گروه: رشته ای، عددی، تاریخ/زمان.
- ENUM یک مقدار از لیست می گیرد.
- SET چند مقدار از لیست می گیرد.
- UNSIGNED منفی را حذف می کند؛ ZEROFILL صفر اضافه می کند.
مطالب مرتبط: نماها (Views) برای نمایش داده مجازی. همچنین تاریخ ها (Dates) برای کار با تاریخ.
بیشتر بخوانید: انواع داده MySQL به عنوان مرجع این بخش.