สวัสดีครับ ในบทความนี้จะแจกตัวอย่างโค้ด PHP PDO Insert Multiple Rows หรือการเพิ่มข้อมูลทีละหลายรายการ แบบง่ายๆ ที่เอาไว้ทำระบบที่ต้องการเพิ่มข้อมูลครั้งละมากกว่า 1 รายการในอนาคตครับ *ตัวอย่าง code ที่แจกจะรองรับการทำงาน PHP7 และ PHP8 *ฝึกไว้ครับเผื่อได้ใช้
ตัวอย่างระบบที่ใช้เทคนิค Insert Multiple Rows
1.ระบบ Shopping Cart คลิก
2.ระบบยืมคืนครุภัณฑ์ คลิก
3.ระบบเบิกจ่ายวัสดุสำนักงาน คลิก
4.ระบบ Food POS คลิก
5.ระบบ Coffee Shop คลิก
6.ระบบอื่นๆ เพิ่มเติม คลิก
รวมคลิปสอนปรับพื้นฐาน ภาษา php ฟรี 100 คลิป ++ https://devbanban.com/?p=3940
โค้ดประกอบด้วย
- PHP PDO , Foreach, rowCount
- MySQL
- HTML
- Bootstrap5
- sweet alert
มาเริ่มทำ workshop กันครับ *คอมเม้นอยู่ในโค้ด
1.รวม Workshop PHP PDO ก่อนหน้า คลิก
2.สร้างโฟลเดอร์สำหรับทดสอบ เช่น ชื่อโฟลเดอร์ workshop_pdo *สำหรับคนที่เพิ่งฝึกยังไม่เข้าใจข้อนี้ว่าต้องสร้างไว้ที่ไหน ให้ดูคลิปชุดนี้ก่อน รวมคลิปสอนปรับพื้นฐาน ภาษา php ฟรี 100 คลิป ++ https://devbanban.com/?p=3940
3.ไฟล์เชื่อมต่อฐานข้อมูล ชื่อไฟล์ connect.php
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 |
<?php $servername = "localhost"; $username = "root"; $password = "yourpassword"; //ไม่ได้ตั้งรหัสผ่านก็ลบ yourpassword ออก try { $conn = new PDO("mysql:host=$servername;dbname=workshop_pdo;charset=utf8", $username, $password); // set the PDO error mode to exception $conn->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION); //echo "Connected successfully"; } catch(PDOException $e) { echo "Connection failed: " . $e->getMessage(); } //Set ว/ด/ป เวลา ให้เป็นของประเทศไทย date_default_timezone_set('Asia/Bangkok'); ?> |
4.ตารางที่ใช้ tbl_ot ให้สร้างฐานข้อมูลก่อนนะครับ (ชื่อฐานข้อมูลที่ใช้ workshop_pdo) แล้วคัดลอกโค้ดและคลิกในเมนู sql จากนั้นวาง code สร้างตาราง จากนั้นคลิก Go ก็จะได้ตารางละครับ
1 2 3 4 5 6 7 8 9 10 11 12 |
CREATE TABLE `tbl_ot` ( `no` int(11) NOT NULL, `empID` int(11) NOT NULL COMMENT 'รหัส พนง.', `workHrs` int(1) NOT NULL COMMENT 'ชม.โอที', `workDate` date NOT NULL COMMENT 'วันที่ทำโอที', `dataCreate` timestamp NOT NULL DEFAULT current_timestamp() ) ENGINE=InnoDB DEFAULT CHARSET=utf8; ALTER TABLE `tbl_ot` ADD PRIMARY KEY (`no`); ALTER TABLE `tbl_ot` MODIFY `no` int(11) NOT NULL AUTO_INCREMENT; |
5.ไฟล์ระบบ formOT.php *คอมเม้นอยู่ในโค้ด **ดูคลิปการทำงานให้จบก่อน 1 รอบครับ จะได้รู้ว่าต้องคอมเม้น Code บรรทัดไหน
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 |
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <link href="https://cdn.jsdelivr.net/npm/bootstrap@5.1.1/dist/css/bootstrap.min.css" rel="stylesheet" integrity="sha384-F3w7mX95PdgyTmZZMECAngseQB83DfGTowi0iMjiWaeVhAn4FJkqJByhZMI3AhiU" crossorigin="anonymous"> <title>Basic Mutitple Insert PHP PDO by devbanban.com 2021</title> </head> <body> <div class="container"> <div class="row"> <div class="col-sm-1"></div> <div class="col-sm-11"> <br> <h4> PHP PDO : Multiple Insert Rows <br> ฟอร์มเพิ่มข้อมูลโอที *ไม่เกินวันละ 5 ชม.</h4> <form action="" method="post"> <div class="row g-3 align-items-center mb-3"> <div class="col-sm-1"> <label class="col-form-label">วันที่</label> </div> <div class="col-sm-4"> <input type="date" name="workDate" class="form-control" required> </div> <div class="col-sm-1"> <label class="col-form-label">ชม.</label> </div> </div> <div class="row g-3 align-items-center mb-3"> <div class="col-sm-1"> <label class="col-form-label">รหัสพนง.</label> </div> <div class="col-sm-1"> <input type="number" class="form-control" value="1" readonly> </div> <div class="col-sm-4"> <input type="text" class="form-control" value="นายเอ ทดสอบระบบ" readonly> </div> <div class="col-sm-1"> <label class="col-form-label">ชั่วโมง</label> </div> <div class="col-sm-1"> <input name="empid[1]" type="number" class="form-control" min="1" max="5" required> </div> <div class="col-sm-1"> <label class="col-form-label">ชม.</label> </div> </div> <div class="row g-3 align-items-center mb-3"> <div class="col-sm-1"> <label class="col-form-label">รหัสพนง.</label> </div> <div class="col-sm-1"> <input type="number" class="form-control" value="2" readonly> </div> <div class="col-sm-4"> <input type="text" class="form-control" value="นายบี ทดสอบระบบ" readonly> </div> <div class="col-sm-1"> <label class="col-form-label">ชั่วโมง</label> </div> <div class="col-sm-1"> <input name="empid[2]" type="number" class="form-control" min="1" max="5" required> </div> <div class="col-sm-1"> <label class="col-form-label">ชม.</label> </div> </div> <div class="row g-3 align-items-center mb-3"> <div class="col-sm-1"> <label class="col-form-label">รหัสพนง.</label> </div> <div class="col-sm-1"> <input type="number" class="form-control" value="3" readonly> </div> <div class="col-sm-4"> <input type="text" class="form-control" value="นายซี ทดสอบระบบ" readonly> </div> <div class="col-sm-1"> <label class="col-form-label">ชั่วโมง</label> </div> <div class="col-sm-1"> <input name="empid[3]" type="number" class="form-control" min="1" max="5" required> </div> <div class="col-sm-1"> <label class="col-form-label">ชม.</label> </div> </div> <div class="row g-3 align-items-center mb-3"> <div class="col-sm-1"> </div> <div class="col-sm-4"> <button type="submit" class="btn btn-primary">บันทึกข้อมูล</button> </div> </div> </form> </div> </div> </div> </body> </html> <?php // echo '<pre>'; // print_r($_POST); //ตรวจสอบมี input อะไรบ้าง และส่งอะไรมาบ้าง // echo '</pre>'; //exit(); //ถ้ามีค่าส่งมาจากฟอร์ม if(isset($_POST['empid']) && isset($_POST['workDate']) ){ // sweet alert echo ' <script src="https://code.jquery.com/jquery-2.1.3.min.js"></script> <script src="https://cdnjs.cloudflare.com/ajax/libs/sweetalert/1.1.3/sweetalert-dev.js"></script> <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/sweetalert/1.1.3/sweetalert.css">'; //ไฟล์เชื่อมต่อฐานข้อมูล require_once 'connect.php'; //ประกาศตัวแปรรับค่าจากฟอร์ม $workDate = $_POST['workDate']; //check duplicate $stmt = $conn->prepare("SELECT no FROM tbl_ot WHERE workDate = :workDate"); $stmt->execute(array(':workDate' => $workDate)); //ถ้าบันทึกซ้ำจากวันที่ โดนดีดออกไปหน้าฟอร์ม if($stmt->rowCount() > 0){ echo '<script> setTimeout(function() { swal({ title: "บันทึกข้อมูลซ้ำ !! ", type: "warning" }, function() { window.location = "formAddOT.php"; //หน้าที่ต้องการให้กระโดดไป }); }, 1000); </script>'; }else{ //ไม่ซ้ำ เก็บข้อมูลลงตาราง //sql insert $stmt = $conn->prepare("INSERT INTO tbl_ot (empID, workHrs, workDate) VALUES (:empID, :workHrs, :workDate)"); //แยก key & value ด้วย foreach foreach ($_POST['empid'] as $empID => $workHrs) { $stmt->bindParam(':empID', $empID , PDO::PARAM_INT); $stmt->bindParam(':workHrs', $workHrs , PDO::PARAM_INT); $stmt->bindParam(':workDate', $workDate, PDO::PARAM_STR); $result = $stmt->execute(); //Dumps the information contained by a prepared statement directly on the output แปลเป็นชาวบ้านๆ คือ แสดง sql statment echo 'debugDumpParams <br>'; echo '<hr>'; $stmt->debugDumpParams(); echo '</pre>'; } //foreach $conn = null; //close connect db exit(); if($result){ echo '<script> setTimeout(function() { swal({ title: "บันทึกข้อมูลสำเร็จ", type: "success" }, function() { window.location = "formAddOT.php"; //หน้าที่ต้องการให้กระโดดไป }); }, 1000); </script>'; }else{ echo '<script> setTimeout(function() { swal({ title: "เกิดข้อผิดพลาด", type: "error" }, function() { window.location = "formAddOT.php"; //หน้าที่ต้องการให้กระโดดไป }); }, 1000); </script>'; } //else result } //else chk dup } //isset //devbanban.com ?> |
6.ผลการทำงาน
ลองเอาไปประยุกต์ใช้ดูครับ และฝากติดตาม workshop ต่อๆ ไปด้วยครับผม
Bootstrap5 : https://getbootstrap.com/
แหล่งศึกษา PDO เพิ่มเติม : https://websitebeaver.com/php-pdo-vs-mysqli
List of PDOStatement::bindParam data_type parameters : https://www.php.net/manual/en/pdo.constants.php
ขอแนะนำระบบพร้อมใช้งาน *รายละเอียดและราคาอยู่ใต้คลิป
ระบบพร้อมใช้ทั้งหมด คลิก
ร่วมสนับสนุน ค่ากาแฟ ค่าโฮส devbanban.com ได้ที่
ธนาคารกรุงไทย สาขาเดอะมอลล์ท่าพระ
ชื่อบัญชี นายพิศิษฐ์ บวรเลิศสุธี เลขที่ 878-0-17747-6
————————————————————————————
ธนาคารไทยพาณิชย์ สาขามหาวิทยาลัยราชภัฏธนบุรี
ชื่อบัญชี นายพิศิษฐ์ บวรเลิศสุธี เลขที่ 406-359094-1
fanpage : https://www.facebook.com/sornwebsites/