i
در حال برنامه نویسی و آماده سازی نسخه جدید «وبگو» هستیم، در این نسخه قابلیت ها و ظاهر سایت به کلی متفاوت و کاملتر خواهد بود، این فرآیند زمانبر و از مدتی پیش شروع شده و همچنان ادامه دارد، روند پیشرفت پروژه در این قسمت به صورت درصدی مشخص است و به تناوب به روزرسانی می شود.
نکته:
با توجه به تاریخ نگارش آموزش های سایت و پیشرفت تکنولوژی های مرتبط با وب در سالیان اخیر، محتوای برخی از مطالب قدیمی ممکن است نیاز به ویرایش و به روزرسانی داشته باشند که این کار هم زمان با تهیه نسخه جدید «وبگو» به مرور در حال انجام است، لطفا در استفاده از مطالب سایت به این نکته دقت داشته و حتی المقدور از چند منبع مختلف استفاده نمائید.
article

ساخت دیتابیس، جدول و ردیف با دستور CREATE در MySQL

mysql-create-table

در مطلب گذشته از بخش آموزش مقدماتی MySQL با کلیاتی از پرکاربردترین سیستم مدیریت پایگاه داده آشنا شدیم، گفتیم که به طور معمول پایگاه داده MySQL را با دو روش می توانیم مدیریت کنیم، روش اول استفاده از رابط کاربری برنامه phpMyAdmin و به صورت دستی است که در این خصوص توضیحات مختصری ارائه شد، روش دوم که هدف اصلی ما در این سری از آموزش ها است، ارتباط و مدیریت پایگاه داده MySQL با برنامه نویسی PHP است که بدین منظور در کنار کدهای PHP از برنامه های نرم افزاری کوچکی تحت عنوان اکستنشن در مفسر این زبان باید بهره بگیریم، اکستنش های ارتباط با MySQL در PHP سه مورد هستند، MySQL، MySQLi و PDO که به جهت قدیمی و منسوخ شدن MySQL از توضیح آن صرف نظر می کنیم، اکستنشن PDO نیز به جهت ماهیت کاربرد چندگانه آن در جای خود آموزش داده خواهد شد، در مباحث این بخش از اکستنشن MySQLi (نسخه بهبود یافته اکستنشن MySQL، حرف i به معنی improved است) که به طور اختصاصی برای ارتباط PHP با MySQL طراحی شده به روش برنامه نویسی رویه ای (Procedural) استفاده می کنیم.

نکته 1: دقت کنیم که پایگاه داده MySQL با اکستنشن MySQL دو مفهوم جداگانه هستند، عبارت اول اشاره به سیستم مدریت پایگاه داده MySQL دارد اما عبارت دوم یک برنامه کوچک نرم افزای در مفسر PHP است که به این زبان قابلیت ارتباط با پایگاه داده را می دهد، اکستنشن MySQL اولین اکستنشن PHP برای این منظور بوده و در حال حاضر منسوخ و قدیمی شده است، لذا بهتر است از اکستنشن های جدید مانند MySQLi یا PDO استفاده کنیم.
نکته 2: اکستنشن MySQLi از دو شیوه برنامه نویسی رویه ای (شیوه معمول یا Procedural) و شی گراء (Object-oriented) پشتیبانی می کند، در این سری از آموزش ها صرفا از شیوه رویه ای استفاده خواهیم کرد و شیوه شی گراء را موکول به بخش دیگری می کنیم، یادآور می شویم که دو روش در عمل کارکرد مشابه دارند و تفاوت در شیوه کدنویسی و مدیریت ساختار برنامه و کدها است.

ساخت دیتابیس با دستور CREATE DATABASE در MySQL


علاوه بر شیوه دستی ساخت دیتابیس از طریق برنامه phpMyAdmin، کدهای PHP نیز چنین قابلیتی دارند که با برنامه نویسی بتوانیم دیتابیس مورد نیازمان را بسازیم، این کار با دستور CREATE DATABASE صورت می گیرد که در زیر دیتابیس فرضی db_name را به این روش ساخته ایم:
<?php
//اتصال به دیتابیس
$conn = mysqli_connect("localhost", "username", "password");
if(!$conn) {
    echo "Error!: " . mysqli_connect_errno() . ' - ' . mysqli_connect_error();
    exit;
} else {
    //ساخت دیتابیس
    $sql = "CREATE DATABASE `db_name` DEFAULT CHARACTER SET utf8 COLLATE utf8_persian_ci";
    $query = mysqli_query($conn, $sql);
    if(!$query) {
        echo "Error Creating Database!: " . mysqli_error($conn);
    } else {
        echo "OK!";
    }
}
//پایان اتصال
mysqli_close($conn);
?>
همان طور که در نمونه کد بالا ملاحظه می کنید دستور CREATE به تنهایی کاربردی ندارد و در کنار پارامترهای دیگر کامل می شود، برای ساخت دیتابیس باید در کنار CREATE از دستور DATABASE استفاده کنیم، همچنین برای اعمال تنظیمات دلخواه پارامترهای دیگری مانند DEFAULT CHARACTER SET و COLLATE استفاده شده که کارکرد مشابهی با حالت دستی در برنامه phpMyAdmin دارند، این دستورات یونیکد پیش فرض دیتابیس را تعیین می کنند که برای سازگاری با زبان فارسی باید مقدار utf8 و utf8_persian_ci برای آنها در نظر گرفته شود، ci در عبارت utf8_persian_ci مخفف case-insensitive و به معنی غیرحساس به حروف بزرگ و کوچک است.

ساخت جدول و ستون با دستور CREATE TABLE


پس از ساختن دیتابیس با دستور CREATE DATABASE نوبت به ایجاد جداول و ستون ها است که این کار با دستور CREATE TABLE انجام می شود، در نمونه کد زیر با استفاده از این دستور جدول فرضی tbl_name را با چند ستون id، name و status ساخته ایم:
<?php
//اتصال به دیتابیس
$conn = mysqli_connect("localhost", "username", "password", "db_name");
if(!$conn){
    echo "Error!: " . mysqli_connect_errno() . ' - ' . mysqli_connect_error();
    exit;
} else{
    //ساخت جدول و ستون
    $sql = "CREATE TABLE tbl_name(
    id INT NOT NULL AUTO_INCREMENT PRIMARY KEY,
    name VARCHAR(255),
    status TINYINT(1) DEFAULT 0) ENGINE=MyISAM DEFAULT CHARACTER SET=utf8 COLLATE=utf8_persian_ci";
    $query = mysqli_query($conn, $sql);
    if(!$query){
        echo "Error Creating Table!: " . mysqli_error($conn);
    } else{
        echo "OK!";
    }
}
//پایان اتصال
mysqli_close($conn);
?>
در کد بالا پرس و جوی ساخت یک جدول با سه ستون id، name و status را اجرا کرده ایم و به هر ستون ویژگی هایی را متناسب با نوع و کارکرد آن نسبت داده ایم که در این مرحله از آموزش صرفا جهت آشنایی اولیه به توضیح مختصر آنها می پردازیم، مواردی مانند INT، VARCHAR و TINYINT نشان دهنده نوع داده ای است که در آن ستون ذخیره می شوند، در خصوص انواع داده در MySQL در آموزش های بعدی به طور خاص صحبت خواهیم کرد، پارامتر NOT NULL به این معنی است که ردیف های اطلاعاتی به صورت پیش فرض NULL یا خالی نیستند، AUTO_INCREMENT نیز به این معنی است که مقدار این ستون با هر INSERT اطلاعات به صورت پیش فرض افزایش پیدا می کند و نیازی به مقداردهی آن در هنگام اجرای پرس و جو نیست، پارامتر PRIMARY KEY نیز یک سیستم در MySQL است که کلید اصلی را مشخص می کند، منظور از این عبارت ایجاد کلیدهای منحصر به فرد جهت دسته بندی بهتر و جستجوی سریع تر در بین ردیف های اطلاعاتی است، در این سیستم هر ردیف در هر جدول یک کلید منحصر به فرد خواهد داشت که در هنگام بازیابی اطلاعات کار جستجو بسیار سریع تر خواهد شد، از پارامتر DEFAULT برای درج یک مقدار پیش فرض به صورت خودکار استفاده می شود، در این نمونه کد عدد 0 به عنوان مقدار پیش فرض برای ستون status در نظر گرفته شده است، پارامتر ENGINE=MyISAM برای تنظیم موتور MyISAM به عنوان موتور پیش فرض برای جدولی است که قصد ایجاد آن را داریم (Syntax آن در برخی نسخه ها به صورت TYPE=MyISAM است، در MySQL به طور معمول دو موتور MyISAM و INNODB استفاده می شوند).
نکته 1: تابع mysqli_connect در دستور CREATE TABLE چهار آرگیومنت دارد که مورد آخر نام دیتابیسی است که می خواهیم در آن جدول ساخته شود، در اینجا دیتابیسی که قبلا با دستور CREATE DATABASE ساخته بودیم (db_name) را به عنوان آرگیومنت چهارم درج کرده ایم.
نکته 2: هر درخواستی که از دیتابیس انجام می شود را در اصطلاح پرس و جو یا Query می نامند، MySQL در پرس و جوهای خود از زبانی به نام SQL استفاده می کند که مخفف Structured Query Language است.

نکته مهم: لطفا توجه داشته باشید ادامه سری آموزش های حاضر قدیمی و در حال ویرایش است و به مرور از MySQL به MySQLi به روز خواهد شد، برای برنامه های جدید بهتر است از MySQLi یا PDO استفاده کنیم.

sectionدسته بندی: آموزش مقدماتی » MySQL
related مطالب بیشتر:
» انتخاب ردیف ها با دستور SELECT FROM در MySQL
» آشنایی با mysql_query در php و دیتابیس
» حذف مقادیر از MySQL با دستور DELETE
» استفاده از ORDER و GROUP در MySQL
» توابع تجمعی (Aggregate Functions) در MySQL
commentنظرات (۳۳ یادداشت برای این مطلب ارسال شده است)
نویسنده: طراحی سایت
زمان: ۱۸:۳۱:۲۳ - تاریخ: ۱۳۹۱/۰۸/۲۴
خوب بود ممنون
نویسنده: نیما
زمان: ۰۱:۰۳:۱۳ - تاریخ: ۱۳۹۱/۰۹/۱۳
عالی
نویسنده: علی
زمان: ۲۲:۰۲:۵۵ - تاریخ: ۱۳۹۱/۰۹/۱۹
سلام این کد که کار نمیکنه!...
میگه باید دیتابیس رو سلکت کنیم این کار رو هم که انجام میدم باز نمیشه
از این کد ها استفاده کردم
mysql_select_db("mahdi");
mysql_select_db("mahdi",$con);
con متغیری هست که به mysql کانکت شده
پاسخ: 
سلام
ممنون از یادآوری شما، قسمت mysql_select_db در هنگام منتشر کردن مطلب از قلم افتاده بود که آموزش به طور کامل مجددا تست و تصحیح شد، می توانید از الگوی فعلی استفاده کنید، اگر خطایی دریافت کردید بررسی کنید که دیتابیس را از قبل ساخته باشید و نام آن به درستی درج شده باشد.
نویسنده: web developer
زمان: ۱۴:۰۶:۲۳ - تاریخ: ۱۳۹۱/۱۲/۲۶
درود
ممنون از آموزش های خوب شما
دوست گرامی
آموزش یو تی اف کردن را در کنار آموزش ساخت فرم ثبت نام انجام می دهم.
زمانی که یو تی اف می کند، تنها تیبل اصلی یو تی اف می شود و ستون های زیر مجموعه را یو تی اف نمی کند.
ممنون می شوم راهنمایی کنید
پاسخ: 
سلام
ابتدا یونیکد دیتابیس را در هنگام ایجاد کردن، بر روی utf8_general_ci تنظیم کنید، سپس در هنگام ایجاد جداول و در همان صفحه کد، از دستور ALTER TABLE در انتهای دستور CREATE TABLE استفاده کنید (پیش از اینکه اتصال را خاتمه دهید).
مثال:
mysql_query("CREATE TABLE tb_name(
id INT NOT NULL AUTO_INCREMENT,
PRIMARY KEY(id),
name VARCHAR(255)) ENGINE=MyISAM ")
or die(mysql_error());
echo "جدول با موفقیت ساخته شد!";

mysql_query("ALTER TABLE tb_name
DEFAULT CHARACTER SET utf8
COLLATE utf8_general_ci;")
or die(mysql_error());
echo "یونیکد با موفقیت تنظیم شد!";
نویسنده: ansherli
زمان: ۱۶:۰۲:۰۷ - تاریخ: ۱۳۹۱/۱۲/۲۸
سلام
ببخشید من متوجه نشدم چطوری با دستور ALTER TABLE کارکنم؟
من دیتابیس و جداولم رو دستی ایجاد کردم
الان چطوری این کد رو بهش اضافه کنم ؟
پاسخ: 
سلام
برای حالت دستی، در برنامه phpMyAdmin بر روی جدول مربوطه کلیک کنید و در منوهای بالایی، گزینه SQL را انتخاب نمائید، سپس از نمونه دستور زیر استفاده کنید:
ALTER TABLE table_name CONVERT TO CHARACTER SET utf8;
روش توضیح داده شده در آموزش مربوط به حالتی است که جداول را با اجرای فایل های PHP می سازید.
نویسنده: ansherli
زمان: ۱۹:۳۹:۰۵ - تاریخ: ۱۳۹۱/۱۲/۲۸
خیلی ممنونم از راهنماییتون
مسیری که گفتید رفتم ولی توی sql چند تا تب هست که مربوط به کدهای delete , clear, update,select,select * ,insert هستش و توی هر کدوم کدهای مربوطه به اون !
مثلا توی insert:
INSERT INTO `akhbar`(`id`, `onvan_khabar`, `aks_khabar`, `matn_khabar`, `datetime`) VALUES ([value-1],[value-2],[value-3],[value-4],[value-5])
نوشته شده من کدی گفتید رو کجا اضافه کنم؟ در ضمن گزینه save توی این صفحه نیست! این کد رو که اضافه میکنم دوباره که برمیگردم به این صفحه چیزی save نشده!
ممنون میشم بگید چیکار کنم ؟
پاسخ: 
وقتی یک جدول را انتخاب کردید و وارد قسمت sql شدید، نیازی نیست سایر دکمه ها را انتخاب کنید، در فیلد متنی Run SQL query/queries on database مقادیر پیش فرض را حذف و پرس و جوی گفته شده را قرار دهید، سپس در پائین صفحه سمت راست بر روی دکمه GO کلیک کنید!
نویسنده: ansherli
زمان: ۲۲:۴۴:۴۳ - تاریخ: ۱۳۹۱/۱۲/۲۸
ببخشید من دقیقا مسیری که شما میگید رو رفتم و کدی که گفتید رو وارد کردم ولی بازم هیچ تغییری توی داده ها ایجاد نشد حتی داده جدیدم وارد کردم ولی بازم فارسی نیست! :(
پاسخ: 
اگر یونیکد ستون های شما utf8_general_ci باشد، داده ها به شکل فارسی ذخیره می شوند (البته در حالت وارد کردن به صورت دستی) اگر هم به شکل کاراکترهای ناخوانا وارد شوند باز مشکلی نیست و در هنگام نمایش در صفحات utf8 به صورت فارسی نمایش داده می شوند، اما برای اطمینان بهتر است داده ها را با دستورات php در دیتابیس ذخیره کنید و پس از اتصال و انتخاب دیتابیس، پرس و جوی زیر را هم اجرا کنید تا تمام فرآیند ها به صورت فارسی ذخیره یا بازیابی شوند:
mysql_query ("SET NAMES 'utf8' ");
نویسنده: صادق
زمان: ۲۰:۱۶:۵۸ - تاریخ: ۱۳۹۲/۰۳/۱۵
سلام یه سوال داشتم که شاید خیلی به این مطلب مربوط نباشه من میخوام یک عکس رو در mysql ذخیره کنم و سپس اون عکس رو دوباره مشاهده کنم اولا نوع داده دیتابیسم چی باید باشه و چگونه ببینم
پاسخ: 
سلام
ذخیره تصاویر در دیتابیس در وب چندان توصیه نمی شود، چون برای نمایش آن (در برخی مرورگرها) ممکن است با مشکلاتی روبرو شوید و از طرفی حجم کلی پایگاه داده به میزان زیادی افزایش می یابد، بهتر است تصاویر را به صورت معمول در هارددیسک سرور ذخیره و تنها آدرس یا نام آنها را در دیتابیس ثبت کنید.
اما جهت اطلاعات بیشتر، نوع داده برای ذخیره تصاویر در MySQL نوع BLOB به معنی Binary Large OBject است که برای نمایش تصویر باید یک دستور header تنظیم کنید:
header("Content-type: image/jpeg");
echo $row['image_column'];
توجه کنید که قبل از این دستورات هیچ خروجی نباید به مرورگر ارسال شود (شامل کاراکترهای نامرئی BOM نیز می شود)، روش دیگر نمایش، استفاده از data:image و base64_encode است:
<?php echo '<img src="data:image/jpeg;base64,' . base64_encode($row['image_column']) . '">'; ?>
نویسنده: صادق
زمان: ۱۰:۱۴:۵۱ - تاریخ: ۱۳۹۲/۰۳/۱۶
خیلی ممنون
نویسنده: صبا
زمان: ۱۳:۱۲:۴۲ - تاریخ: ۱۳۹۲/۰۳/۲۸
سلام، به خاطر مطالب خيلي خوبتون ممنونم. يه سوال وقتي دستور ساخت دیتابیس با دستور CREATE رو مينويسم اين خطا رو ميده در ضمن من از wampserver استفاده ميكنم.مشكل از كجاست
اتصال برقرار نشد: Access denied for user 'username'@'localhost' (using password: YES)
پاسخ: 
سلام
به احتمال زیاد در هنگام اتصال به دیتابیس در لوکال هاست، قسمت مربوط به کلمه عبور را نیز مقداردهی می کنید، در حالی که معمولا در لوکال هاست با نام کاربری root و بدون پسورد باید به دیتابیس متصل شد (البته با توجه به تنظیمات پیش فرض).
نویسنده: pietra grey marble
زمان: ۱۰:۴۱:۱۵ - تاریخ: ۱۳۹۲/۰۴/۲۷
ممنون
نویسنده: yahya
زمان: ۰۹:۳۵:۴۱ - تاریخ: ۱۳۹۲/۰۵/۰۲
با سلام و تشکر از زحمات شما
یک سوال داشتم آیا امکان افزودن ستون به جدول بعد از ایجاد جدول وجود دارد . اگر این امکان وجود دارد دستور مربوط به آن چیست؟
پاسخ: 
سلام
بله با ALTER می توانید تغیرات بعدی را در جدول ایجاد کنید، به طور مثال:
mysql_query("ALTER TABLE tbl_name ADD COLUMN new_col_name INT(11) NOT NULL DEFAULT 0 AFTER col_name")
or die(mysql_error());
کد بالا یک ستون فرضی از نوع INT بعد از ستون col_name می سازد.
نویسنده: علی
زمان: ۱۹:۵۷:۴۸ - تاریخ: ۱۳۹۲/۰۶/۳۱
سلام. ببخشید برای ساخت جدول در mysql محدودیت تعداد کارکتر رو باید بدیم. چطوری این مقدار رو نامحدود کنم که تعداد کاراکتر مهم نباشه.
پاسخ: 
سلام
تا آنجا که اطلاع داریم، امکان ساخت ستون بدون محدودیت کاراکتر در MySQL وجود ندارد، اما می توانید از data type های زیر استفاده کنید:
TINYTEXT - 255 bytes
TEXT - 65535 bytes
MEDIUMTEXT - 16,777,215 bytes (2^24 - 1)
LONGTEXT - 4G bytes (2^32 – 1)
که برای متن های خیلی خیلی طولانی (در حد حجم 4 گیگابایت)، LONGTEXT انتخاب مناسبی است.
نویسنده: حراج
زمان: ۱۸:۲۷:۵۸ - تاریخ: ۱۳۹۲/۰۸/۰۱
عالی و ممنون
نویسنده: یاسمن
زمان: ۱۱:۰۷:۰۸ - تاریخ: ۱۳۹۲/۱۰/۲۰
وقتی دستور ایجاد دیتا بیس رو می زنم این پیغام رو میده:
خطایی رخ داده است:
Access denied for user ''@'localhost' to database 'db_name
پاسخ: 
به نظر کدهای شما اشکالی دارد و اطلاعات مورد نیاز برای اتصال به پایگاه داده (نام کاربری، کلمه عبور، نام دیتابیس و...) به درستی تنظیم نشده است.
paged صفحه 1 از 3




more لطفا دقت کنید که یادداشت های زیر منتشر نشده و حذف خواهند شد:
- یادداشت های خارج از موضوع این مطلب.
- سوالات کلی، غیر ضروری و مشکلاتی که هیچ تلاشی برای رفع آن نکرده باشید.
- نظرات حاوی کدها و اسکریپت های خیلی طولانی (به طور مثال کد کامل قالب وبلاگ).

1 × 4
 refresh
آگهی
رنگین کمان عکس
Ranginkamaan.com

آرشیو عکس های باکیفیت با موضوعات متنوع...
پرشین آی تی
Persianit.net

آموزش و دانلود پروژه های برنامه نویسی سی شارپ (#C)