ให้เรตสมาชิก: 4 / 5

ดาวใช้งานดาวใช้งานดาวใช้งานดาวใช้งานดาวไม่ได้ใช้งาน
 

สอน php เชื่อมต่อฐานข้อมูล การใช้คำสั่งในการ INSERT ข้อมูลลงฐานข้อมูล

ในตัวอย่างนี้เราจะทำการสร้าง ฟอร์มรับข้อมูลไว้ในไฟล์ form.php  หลังจากนั้นจะให้ส่งค่าไปยัง ไฟล์ save.php เพื่อทำการ insert  ข้อมูลลงฐานข้อมูล ในการสร้างไฟล์ save.php เราจะต้องมีการเชื่อมต่อกับฐานข้อมูลขึ้นมาก่อน connect.php  เมื่อทำการ insert จะนำข้อมูลไปแสดง ในหน้า list.php
ในตัวอย่างเราจะทำการ INSERT  ข้อมูลลงใน ตาราง  test สิ่งเเรกก่อนเราจะต้องทำการสร้างตารางเพื่อรับข้อมูล

จากนั้นทำการสร้าง form ตามโครงสร้างของตาราง

ไฟล์ตัอย่าง form.php
<form neme="form" method="post" action="save.php" enctype="multipart/form-data">
<label>Title:</label><input type="text"name="rank_title" /><br/>
<label>Min:</label><input type="text"name="rank_min"/>
<label>special:</label>
<input type="radio"name="rank_special"id="rank_special1" value="1"checked="checked"/>
<label for="rank_special1">yes</label>
<input type="radio"name="rank_special"id="rank_special2"value="0"/>
<label for="rank_special2">no</label><br/>
<label>image:</label>
<input type="file"name="rank_image"/><br/>
<input type="submit" neme="save" value="save" />

คำอธิบาย

<form neme="form" method="post" action="save.php" enctype="multipart/form-data">

ในการสร้างฟอร์ม เราจะเห็นว่ามีการ ส่งค่า  method="post"  ไปยังไฟล์ save.php  เเละในส่วนของ enctype="multipart/form-data เป็นการกำหนดให้ฟอร์มนี้มีการเก็บข้อมูลได้หลายประเภท

<label>Title:</label><input type="text"name="rank_title" /><br/>
<label>Min:</label><input type="text"name="rank_min"/>

ในการเก็บข้อมูล rank_Tilte ,rank_Min จะทำการเก็บในรูปแบบ input type"text" name=ก็ชื่อฟิลด์ของตาราง

<label>special:</label>
<input type="radio"name="rank_special"id="rank_special1" value="1"checked="checked"/>
<label for="rank_special1">yes</label>
<input type="radio"name="rank_special"id="rank_special2"value="0"/><label>special:</label>
<input type="radio"name="rank_special"id="rank_special1" value="1"checked="checked"/>
<label for="rank_special1">yes</label>
<input type="radio"name="rank_special"id="rank_special2"value="0"/>

ในการเก็บ special เราจะเก็บในรูปแบบ radio  ให้มีการตรวจสอบค่า เริ่มต้นถ้าไม่มีการคลิกให้กำหนดเป็น value 1 value="1"checked="checked”

<label>image:</label>
<input type="file"name="rank_image"/><br/>

Image เราจะเก็บเป็นการอัพโหลดไฟล์รูป type="file"

<input type="submit" neme="save" value="save" />

 การสร้าง ปุ่ม

 

ไฟล์ connect.php
<?php
$host ='localhost';
$username ='root';
$password ='';
$db ='test';
mysql_connect($host,$username,$password) or die ('error connect');
mysql_query('set name utf8');
mysql_select_db($db)or die('select error');
?>

คำอธิบาย
การสร้างไฟล์ที่ใช้ในการเชื่อมต่อ กับฐานข้อมูล

$host = ชื่อโฮลต์
$username = ชื่อผู้ใช้ฐานข้อมูล
$password = รหัสผ่านในการเข้าฐานข้อมูล
$db = ชื่อตาราง
mysql_connect = คำสั่ง sql ในการเชื่อมต่อฐานข้อมูล
mysql_query = set ค่าของภาษา
mysql_select_db = คำสั่งเลือกตาราง

 

ไฟล์ save.php
<?php
require_once'connect.php';
if(isset($_POST['save']));{
if(!empty($_FILES['rank_image']['name'])){
$filename = md5($_FILES['rank_image']['name'].time());
$ext = explode('.',$_FILES['rank_image']['name']);
$dest = __DIR__.DIRECTORY_SEPARATOR.'image'.DIRECTORY_SEPARATOR.$filename.'.'.$ext[1];
if(!copy($_FILES['rank_image']['tmp_name'], $dest)) {
echo 'upload Error';
exit();

}
$rank_image = $filename.'.'.$ext[1];
}

$rank_title =$_POST['rank_title'];
$rank_min =$_POST['rank_min'];
$rank_special =$_POST['rank_special'];

$sql = "INSERT INTO phpbb_ranks (rank_title,rank_min,rank_special,rank_image)"
. "VALUES('$rank_title',$rank_min,$rank_special,'$rank_image')";

mysql_query($sql)or die ('insert error');
header('location: lish.php');

}
?>

คำอธิบาย

require_once'connect.php'; 

คือ การเรียกไฟล์ connect.php เข้ามาใช้งานโดยไม่ต้องเขียนคำสั่งเชื่อมต่อฐานข้อมูลอีก

if(isset($_POST['save']));

การตรวจสอบการกด ปุ่ม คือ ถ้ามีการกด ปุ่มจะมีการทำงานของโค้ดต่อไป

if(!empty($_FILES['rank_image']['name'])){
$filename = md5($_FILES['rank_image']['name'].time());
$ext = explode('.',$_FILES['rank_image']['name']);
$dest = __DIR__.DIRECTORY_SEPARATOR.'image'.DIRECTORY_SEPARATOR.$filename.'.'.$ext[1];
if(!copy($_FILES['rank_image']['tmp_name'], $dest)) {
echo 'upload Error';
exit();

}
$rank_image = $filename.'.'.$ext[1];
}

คำสั่งเช็คการอัพโหลดไฟล์ภาพ ถ้าไม่มีการอัพโหลดภาพก็ไม่ต้องทำการเก็บภาพ ถ้ามีให้ทำงานตามคำสั่งการคัดลอกภาพไปเก็บที่ $dest คือตำแหน่งของโฟลเดอร์ที่เราต้องการให้มันคัดลอกไปไว้ แล้วถ้าคัดลอกไม่ผ่าน ก็จะแสดง upload Error เมื่อทำการ คัดลอกไฟล์สำเร็จจะเก็บ ในตัวแปร $rank_image เพื่อใช้ในคำสั่ง insert
ต่อไป จากนั้นให้ทำการสร้างโฟล์เดอร์ในการเก็บภาพ

 

       $rank_title =$_POST['rank_title'];
$rank_min =$_POST['rank_min'];
$rank_special =$_POST['rank_special'];

การประกาศตัวแปรรับค่า POST ที่เป็นการเก็บค่าในรูปแบบ text และ radio

 

        $sql = "INSERT INTO  phpbb_ranks (rank_title,rank_min,rank_special,rank_image)"
. "VALUES('$rank_title',$rank_min,$rank_special,'$rank_image')";

คำสั่ง sql insert ให้มีการบันทึกข้อมูล ลงตาราง phpbb_ranks โดย (rank_title,rank_min,rank_special,rank_image) จะเป็นชื่อของฟิลด์ในตาราง เเละ VALUES ใส่ค่าตัวแปรที่เราประกาศไว้ สังเกตุ ถ้าเป็นการเก็บ แบบ string จะต้องใส่เครื่องหมาย ‘’
เพื่อระบุว่าเป็น string

 ในส่วนของการดึงข้อมูลจากฐานข้อมูลมาเเสดงผล เราจะทำการใช้คำสั่ง sql ในการเลือกว่าเราจะทำการแสดงข้อมูลตารางใด ในตัวอย่างนี้เราจะทำการดึงข้อมูลของตารางมาแสดงทั้งหมด

 

ไฟล์ list.php
<?php
require_once 'connect.php';
$sql ="SELECT * FROM phpbb_ranks";
$result = mysql_query($sql);
?>
<html>
<head>
<meta charset="UTF-8">
<title></title>
</head>
<body>
<table border="1">
<tr>
<th>id</th>
<th>rank title</th>
<th>rank min</th>
<th>rank special</th>
<th>rank image</th>

</tr>
<?php
while ($fetch = mysql_fetch_assoc($result)){

?>
<tr>
<td><?php echo $fetch['rank_id']?></td>
<td><?php echo $fetch['rank_title']?></td>
<td><?php echo $fetch['rank_min']?></td>
<td><?php echo $fetch['rank_special']?></td>
<td><?php echo $fetch['rank_image']?></td>

<?php
}
?>
</table>
</body>
</html>

คำอธิบาย

<?php
require_once 'connect.php';
$sql ="SELECT * FROM phpbb_ranks";
$result = mysql_query($sql);
?>

คำสั่ง sql ในการดึงข้อมูลจากฐานข้อมูล

<?php
    while ($fetch = mysql_fetch_assoc($result)){
?>

การดึงข้อมูลมาแสดงผลในรูปของตาราง โดยจะทำการ วนลูปในการแสดงผล

<td><?php echo $fetch['rank_id']?></td>
<td><?php echo $fetch['rank_title']?></td>
<td><?php echo $fetch['rank_min']?></td>
<td><?php echo $fetch['rank_special']?></td>
<td><?php echo $fetch['rank_imagel']?></td>

การใช้คำสั่ง php ในการดึงข้อมูลเพื่อเเสดงผล

 

 

ชื่อ
การใช้คำสั่งในการ INSERT ข้อมูลลงฐานข้อมูล
หมวดหมู่
PHP Basics, PHP Basics
ฮิต
11400
ผู้สร้างเอกสาร
thatsawan
วันที่สร้างเอกสาร
2014-05-13 19:26:02

การใช้คำสั่งในการ INSERT ข้อมูลลงฐานข้อมูล.zip

ประเภทไฟล์ zip

ขนาดไฟล์ 1.37 KB

ผู้อัพโหลดไฟล์ thatsawan

วันที่อัพโหลด 2014-05-07 15:31:42


 

กระทู้ล่าสุดจากเว็บบอร์ด
หัวข้อกระทู้
ตอบ
เปิดดู
ล่าสุด
Liverpool เจ้ายุโรป 5 สมัย
โดย Before Dong พฤ 22 ก.พ. 2018 11:14 am บอร์ด พูดคุยเรื่องทั่วไป จับฉ่าย
0
15
พฤ 22 ก.พ. 2018 11:14 am โดย Before Dong
การใช้งาน Python GUI (Tkinter) :Label widget (วิดเจ็ตป้ายกำกับ)
โดย Jom07 พ 21 ก.พ. 2018 5:36 pm บอร์ด Python Knowledge
0
10
พ 21 ก.พ. 2018 5:36 pm โดย Jom07
รูปแบบการดึงข้อมูลจากฐานข้อมูลใน Joomla
โดย Parichat พ 21 ก.พ. 2018 5:25 pm บอร์ด Joomla Developing Knowledge
0
7
พ 21 ก.พ. 2018 5:25 pm โดย Parichat
การใช้ปุ่ม Button ชนิดต่างๆ ใน Python GUI (Tkinter)
โดย Jom07 พ 21 ก.พ. 2018 5:07 pm บอร์ด Python Knowledge
0
13
พ 21 ก.พ. 2018 5:07 pm โดย Jom07
Slideshow CK (สไลด์โชว์ ซีเค)-Module ที่สามารถแสดงรูปภาพและวีดีโอที่มีลิ้งที่มีลักษณะพิเศษได้
โดย Parichat พ 21 ก.พ. 2018 4:11 pm บอร์ด Joomla Extension Review
0
13
พ 21 ก.พ. 2018 4:11 pm โดย Parichat
มีใครใช้ Zoho Creator ทำแอพมั้ยคะ ช่วยด้วยค่ะ
โดย 156595465 พ 21 ก.พ. 2018 3:14 pm บอร์ด Mobile Programming - Android, iOS, Window Phone
0
18
พ 21 ก.พ. 2018 3:14 pm โดย 156595465
วิวัฒนาการของการเก็บข้อมูล
โดย Before Dong พ 21 ก.พ. 2018 10:42 am บอร์ด พูดคุยเรื่องทั่วไป จับฉ่าย
0
24
พ 21 ก.พ. 2018 10:42 am โดย Before Dong
มีใครใช้ Zoho Creator เขียนแอพตัวเองมั้ยคะ
โดย 156595465 พ 21 ก.พ. 2018 6:25 am บอร์ด Mobile Programming - Android, iOS, Window Phone
0
15
พ 21 ก.พ. 2018 6:25 am โดย 156595465
Q :ต้องการบันทึกข้อมูลการคำนวนระยะทางตอนที่ผู้ใช้งานค้นหาจากจังหวัดต้นทางและจังหวัดปลายทาง ใน Joomla
โดย Parichat อ 20 ก.พ. 2018 6:43 pm บอร์ด Joomla Development
1
26
อ 20 ก.พ. 2018 7:31 pm โดย tsukasaz
Modals (โม'เดิล)-Plugin ที่ทำให้เชื่อมโยงที่เปิดในป็อปอัพโมเดิล
โดย Parichat อ 20 ก.พ. 2018 6:20 pm บอร์ด Joomla Extension Review
0
21
อ 20 ก.พ. 2018 6:20 pm โดย Parichat
การใช้งาน Python GUI (Tkinter) :Create List box (สร้างกล่องรายการ)
โดย Jom07 อ 20 ก.พ. 2018 3:07 pm บอร์ด Python Knowledge
0
35
อ 20 ก.พ. 2018 3:07 pm โดย Jom07
คู่มือ VDO
โดย tsukasaz อ 20 ก.พ. 2018 2:58 pm บอร์ด RTP - Right To Play Thailand Foundation (7 ก.พ. - 15 มิ.ย.61)
0
3
อ 20 ก.พ. 2018 2:58 pm โดย tsukasaz
ประชุมทีม
โดย tsukasaz อ 20 ก.พ. 2018 2:57 pm บอร์ด RTP - Right To Play Thailand Foundation (7 ก.พ. - 15 มิ.ย.61)
0
1
อ 20 ก.พ. 2018 2:57 pm โดย tsukasaz
ไฟล์ตัวติดตั้ง
โดย tsukasaz อ 20 ก.พ. 2018 2:57 pm บอร์ด RTP - Right To Play Thailand Foundation (7 ก.พ. - 15 มิ.ย.61)
0
1
อ 20 ก.พ. 2018 2:57 pm โดย tsukasaz
รายงานความคืบหน้า / Progress
โดย tsukasaz อ 20 ก.พ. 2018 2:56 pm บอร์ด RTP - Right To Play Thailand Foundation (7 ก.พ. - 15 มิ.ย.61)
0
1
อ 20 ก.พ. 2018 2:56 pm โดย tsukasaz
G - ข้อมูลสำหรับทำระบบ RTP - ระบบติดตามและประเมินผลและบริหารข้อมูลโครงการ
โดย mindphp อ 20 ก.พ. 2018 2:05 pm บอร์ด RTP - Right To Play Thailand Foundation (7 ก.พ. - 15 มิ.ย.61)
1
9
อ 20 ก.พ. 2018 4:04 pm โดย mindphp
การทำงานของ Front-End กับ Back-End
โดย Before Dong อ 20 ก.พ. 2018 9:57 am บอร์ด พูดคุยเรื่องทั่วไป จับฉ่าย
0
1267
อ 20 ก.พ. 2018 9:57 am โดย Before Dong
Q :ต้องการให้ระยะทางที่คำนวนได้มาแสดง โดยได้มาจากจังหวัดต้นทางและปลายทางที่กำหนดค่า default เอาไว้
โดย Parichat จ 19 ก.พ. 2018 5:48 pm บอร์ด Joomla Development
73
250
พฤ 22 ก.พ. 2018 3:00 pm โดย Parichat
package tkFileDialog (python 2) เปลี่ยนตัวแปรเป็น filedialog (python 3)
โดย Jom07 จ 19 ก.พ. 2018 5:35 pm บอร์ด Python Knowledge
0
23
จ 19 ก.พ. 2018 5:35 pm โดย Jom07
Q :ต้องการให้ listbox selected จากรายการที่เคยคำนวนระยะทางมาก่อนแล้วใน Joomla
โดย Parichat จ 19 ก.พ. 2018 3:32 pm บอร์ด Joomla Development
10
65
จ 19 ก.พ. 2018 4:36 pm โดย Parichat