ข้ามไปที่เนื้อหาหลัก

บทความ

กำลังแสดงโพสต์จาก กรกฎาคม, 2019

CodeIgniter CRUD Generator - การสร้าง Core Controller เพื่อแก้ปัญหาต้องเขียนคำสั่งซ่อนแสดงเมนู ในทุกๆหน้า

ซ่อนแสดงเมนูของ Admin เริ่มจากสร้างไฟล์ แล้วก็ย้ายตัวแปรบางส่วนออกไปที่ไฟล์ใหม่ โดยมีขั้นตอนดังต่อไปนี้ 1. สร้างไฟล์ core/CRUD_Controller.php ( ดูซอร์สโค้ดได้ท้ายบทความนี้ ) 2. แก้ไขไฟล์ core/MEMBER_Controller.php ให้ extends จาก CRUD_Controller.php ที่สร้างในข้อที่ 1 โดยแก้จากเดิม class MEMBER_Controller extends CI_Controller เป็น class MEMBER_Controller extends CRUD_Controller  3. แก้ไขไฟล์ Controller แต่ละ หน้าเว็บเพจ ที่สร้างขึ้นมาให้ extends CRUD_Controller ให้เหมือนกันทั้งหมด และลบตัวแปรบางบรรทัดออกเช่น    3.1 แก้ extends CRUD_Controller    3.2 ลบตัวแปรที่ซ้ำ กับ CRUD_Controller ออก    3.3 แก้ตัวแปร 2 ตัวที่เหลือ จาก $data เป็น $this->data    หน้าตาไฟล์ Controller ของเว็บเพจที่เราแก้ไขเรียบร้อยจะได้ดังนี้ 4. แก้ไข left_sidebar_view.php  <ul class="sidebar navbar-nav">     <li class="nav-item active">         <a class="nav-li...

การสร้างเว็บไซต์ ระบบบริหารจัดการร้านกาแฟ ด้วย PHP & MySQL

ระบบบริหารจัดการร้านกาแฟ ด้วย PHP & MySQL แนวคิด ระบบบริหารจัดการ ร้านกาแฟ ปรับแต่งเทมเพลต SB Admin 2 สำหรับใช้กับโปรเจ็กต์ Coffee Shop - PHP CI MANIA ออกแบบฐานข้อมูลโครงสร้างบริษัท  ชื่อกิจการ สาขา และสร้างเว็บเพจบันทึกข้อมูลบริษัท  ออกแบบฐานข้อมูล แผนก/ฝ่าย ตำแหน่ง รายชื่อพนักงาน และสร้างเว็บเพจบันทึกข้อมูล ออกแบบฐานข้อมูล สร้างเมนูเครื่องดื่ม และสร้างเว็บเพจบันทึกรายชื่อเมนู  ออกแบบฐานข้อมูล รายการวัตถุดิบ และสร้างเว็บเพจบันทึกรายชื่อวัตถุดิบ/วัสดุ ออกแบบฐานข้อมูล ตารางส่วนผสม และสร้างเว็บเพจบันทึกรายชื่อการส่วนผสมแต่ละเมนู ออกแบบตารางเก็บประวัติการขาย รายงานประจำวัน และสร้างเว็บเพจบันทึกข้อมูล ออกแบบตารางเก็บค่าใช้จ่าย รายงานค่าใช้จ่าย สร้างเว็บเพจบันทึกค่าใช้จ่ายประจำวัน สร้างเว็บเพจแสดงรายงานประจำวัน / ประจำเดือน / ประจำปี สร้างเว็บเพจแสดงรายงานสรุป รายรับ-รายจ่าย ประจำเดือน สร้างเว็บเพจประเมินสต๊อกวัตถุดิบคงเหลือ สร้างเว็บเพจบันทึกรายการสั่งซื้อวัตถุดิบ สร้างเว็บเพจ นำเข้าสต๊อกวัตถุดิบตามรายการสั่งซื้อ สร้างเว็บเพจปรับปร...

PHP CI MANIA : ตอนที่ 19 วิธีสร้างเว็บเพจอย่างง่าย ในการคลิกเพียงครั้งเดียว!!

คุณสมบัติพิเศษ สำหรับ PHP CI MANIA เวอร์ชั่น 0.6 ก็คือ "สามารถสร้างเว็บเพจได้ง่ายๆ ในคลิกเดียว" ซึ่งในเวอร์ชั่นอื่นๆ จะต้องคลิกสร้างทีละไฟล์ 1. ในแท็ป " ตั้งค่า " ของ Version 0.6 จะปรากฏปุ่ม " สร้างไฟล์ทั้งหมด " ด้านขวามือ 2. เมื่อตั้งค่าต่างๆเรียบร้อยตามที่ต้องการแล้ว ให้คลิกที่ปุ่ม " สร้างไฟล์ทั้งหมด " ระบบจะเริ่มสร้างไฟล์ทีละส่วนจนครบทั้งหมด และจบที่หน้า Controller เพื่อให้ คลิกเพื่อดูตัวอย่าง ที่สร้างมาเรียบร้อยแล้ว เมื่อตรวจสอบการทำงานเรียบร้อยก็สามารถ คัดลอก ไฟล์นำไปใช้งานได้เลยครับ อ่านวิธีการนำโค้ดไปใช้งานได้ที่ PHP CI MANIA : ตอนที่ 4 การนำโค้ด ไปใช้งานใน Project ที่เตรียมไว้ วิดีโอสาธิตการทำงาน : << บันทึกการตั้งค่า เพื่อแก้ไขภายหลัง คู่มือ PHP CI MANIA » [[ PHP CI MANIA | ลดเวลาเขียนโค้ด เพิ่มเวลาบริหารจัดการได้มากขึ้น | Webpage Generator by CodeIgniter Framework ]] HOME   --------------------------------   สนับสนุนค่ากาแฟผู้เขียนได้ที่ PHP  CI  MANIA   - PHP Code Generator  โปรแกร...

PHP CI MANIA : ตอนที่ 18 การบันทึกข้อมูลการตั้งค่า Setting เพื่อใช้ปรับแต่งในภายหลัง

หลายครั้งในระหว่างที่แอดมินกำลังตั้งค่า ก็จะมีบ้างที่เผลอกดรีเฟรชผิดหน้า ทำให้ค่าที่ตั้งเอาไว้หายไปหมดต้องมานั่งตั้งค่าใหม่ หรือบางครั้งก็สร้างไฟล์เรียบร้อยแล้วแต่มันยังไม่ได้สมบูรณ์จริง แต่ก็ดันปิดหน้าตั้งค่าไปเสียแล้ว บทความตอนนี้ จะมาแนะนำวิธีการบันทึกค่าสำหรับ Version 0.6 เพื่อให้สามารถเรียกคืนค่ามาใช้ภายหลังได้อีกครั้ง โดยไม่ต้องมานั่งตั้งค่ากันใหม่อีกต่อไป 1. ในแท็ป " ตั้งค่า " ของ Version 0.6 จะปรากฏปุ่ม " บันทึกการตั้งค่า " ด้านขวามือ 2. เมื่อได้ตั้งค่าตัวเลือกต่างๆ อาจจะอยู่ในระหว่างตั้งค่า หรือจะรอจนตั้งค่าต่างๆเรียบร้อยก็แล้วแต่ ท่านสามารถคลิกปุ่ม "บันทึกการตั้งค่า" เพื่อจำข้อมูลการตั้งค่าได้ตลอดเวลา 3. โดยข้อมูลอ้างอิงในการตั้งค่าจะมีอยู่ด้วยกัน 4 ค่า ดังนี้        1. Table name : ชื่อตารางหลักที่เลือก        2. Module name : ชื่อ Module ที่กำหนด        3. Controller name : ชื่อ Controller ที่กำหนด        4. Model name : ชื่อ Model ที่...

PHP CI MANIA : ตอนที่ 17 การกำหนดให้คำนวณราคารวมแบบอัตโนมัติ เมื่อเปลี่ยนรายการวัตถุดิบใหม่ (On Change)

จากที่ได้กำหนด Action หลังจากกรอกจำนวนลงใน INPUT ให้คำนวณราคารวมในตอนที่แล้ว ( PHP CI MANIA : ตอนที่ 16 วิธีสร้างเว็บเพจที่มีแบบฟอร์มคำนวณผลรวมอัตโนมัติ เมื่อป้อนข้อมูลในช่อง INPUT ) เรายังสามารถกำหนด Action ให้กับ Dropdown ที่ JOIN ตารางวัตถุดิบให้คำนวณราคารวมทุกครั้งเมื่อเกิดการเปลี่ยนแปลงได้อีกด้วย 1. ในแท็ป " ตั้งค่า " เลื่อนไปส่วนที่ 5 ด้านล่างสุด " ข้อมูลตารางรายการ ( Detail ) " และกำหนดการ JOIN ตารางวัตถุดิบที่ไอคอนด้านซ้าย 2. จะมีการกำหนดค่าเพิ่มเติมในขั้นตอนที่ 2.4 และ 2.5 สำหรับขั้นตอนที่ 2.1 - 2.3 คือการตั้งค่าการ JOIN ตามปกติ ( อ่านได้จากคู่มือการใช้งาน ตอนที่ 8 )        2.1 เลือกตารางวัตถุดิบ  (ตารางที่ต้องการ JOIN)        2.2 เลือกฟิลด์อ้างอิง (Primary key ของตารางที่ JOIN)        2.3 เลือกฟิลด์ที่ใช้แสดงเป็นป้ายกำกับใน Dropdown list ที่สร้างขึ้นมา        2.4 ตั้งค่าเพิ่มเติม เพื่อดึง ราคา มาเก็บไว้ในแอตทริบิวต์ของ option ที่เลือก เพื่อใช...

PHP CI MANIA : ตอนที่ 16 วิธีสร้างเว็บเพจที่มีแบบฟอร์มคำนวณผลรวมอัตโนมัติ เมื่อป้อนข้อมูลในช่อง INPUT

การคำนวณผลรวม เมื่อเปลี่ยนแปลงตัวเลขใน Textbox หากเขียนโค้ดเองก็เพียงไม่กี่บรรทัด แต่ถ้าหากใช้ PHP CI MANIA เราสามารถเพิ่มการตั้งค่าได้ดังนี้ 1. ในแท็ป " ตั้งค่า " เลื่อนไปส่วนที่ 5 ด้านล่างสุด " ข้อมูลตารางรายการ ( Detail ) " 2. เพิ่ม INPUT สำหรับแสดงราคารวม โดยคลิกที่ปุ่มสีเขียว ในตัวอย่างนี้จะสร้างไว้ต่อจาก ฟิลด์ ราคา  โดยกำหนดค่าในช่องคอลัมน์ Name เป็น total_price=>ราคารวม สังเกตุว่าจะมี => คั่นกลาง        ด้านซ้าย total_price ใช้เป็นไอดีอ้างอิงเพื่อนำราคารวมไปแสดงผล        ด้านขวา ราคารวม ใช้เป็นป้ายชื่อหน้าช่องแสดงผลรวม 3. กำหนด Action ให้กับฟิลด์ที่เมื่อเปลี่ยนค่าแล้วจะให้คำนวณผลรวมอัตโนมัติ ในที่นี้คือ ฟิลด์จำนวน 4. กำหนดค่าต่างๆให้กับ Action ของฟิลด์ที่เลือก     4.1  กำหนด Events จะเลือก onkeyup เพื่อจับเหตุการณ์เมื่อพิมพ์ตัวเลขระบุจำนวนสั่งซื้อ ให้คำนวณค่าราคารวมทันที     4.2  INPUT 1  ให้ระบุฟิลด์ที่ใช้ในการคำนวณตัวที่ 1 ที่นี้คือ ฟิลด์จำ...

PHP CI MANIA : ตอนที่ 15 สร้างเว็บเพจ แบบกำหนดรายการที่แสดงในตารางเฉพาะ หน่วยงาน/ผู้ใช้งาน ที่เป็นเจ้าของ เท่านั้น

นอกจากการกำหนดสิทธิ์ระดับหน้าเว็บในตอนที่แล้ว ( PHP CI MANIA : ตอนที่ 14 วิธีสร้างเว็บเพจ Login Form และการตรวจสอบ แผนกที่สังกัด ของผู้ใช้งาน ) เรายังสามารถกำหนดให้ลึกลงไปแบบเฉพาะเจาะจง ให้แสดงเฉพาะรายการที่ตนเองเป็นเจ้าของผู้บันทึกรายการเท่านั้นได้อีกด้วย เช่นหน้าเว็บเพจที่เราสร้างไว้ในตอนก่อนหน้านั้น ถ้าเราไม่กำหนด "WHERE USER SESSION" ก็จะเห็นว่าในตารางรายการนั้น แสดงทุกรายการ ทั้งของ USER 01 และ USER Demo รวมกัน ทั้งที่การ Login เข้ามานั้นเป็นไอดีของ User1 ซึ่งที่จริงแล้วจะต้องแสดงเฉพาะของ User1 เท่านั้น 1. เริ่มจากหน้าตั้งค่า คลิกเลือก " Login Require "  2. จากนั้นเลื่อนไปในส่วนที่ 4 "กำหนดการค้นหา / ประเภทช่องป้อนข้อมูล ตาราง tb_product_order_master ( Master )"  ที่คอลัมน์ " WHERE User Session " กำหนดไปที่ฟิลด์ที่เป็นรหัสอ้างอิงผู้ใช้งาน ในที่นี้คือ order_user_id ให้ระบุตัวเลือกเป็น " SESSION ไอดี ผู้ใช้งาน " (ซึ่งถ้าต้องการให้เห็นในระดับแผนก ก็สามารถอ้างอิงฟิลด์ที่เก็บรหัสแผนก และเลือก SESSION เป็น แผนกที่สังกัด) ...

ค้นหาในเว็บไซต์

เนื้อเพลงที่ได้รับความนิยม ในรอบสัปดาห์

PHP CI MANIA 0.8.4.09 แก้ไขปัญหา Import ไฟล์ Excel แล้วไม่สามารถบันทึกได้ + เพิ่มตัวเลือก Validate บางฟิลด์

- เพิ่มตัวเลือก Validate บางฟิลด์ กรณีละเว้นการตรวจสอบให้เอาเครื่องหมายเช็คถูกออก -  แก้ไขปัญหา Import ไฟล์ Excel แล้วไม่สามารถบันทึกได้ สมาชิก Premium ดาวน์โหลดได้ที่ http://fastcoding.phpcodemania.com/index.php/downloads PHP  CI  MANIA   - PHP Code Generator  โปรแกรมช่วยสร้างโค้ด "ลดเวลาการเขียนโปรแกรม" ราคาสุดคุ้ม    http://fastcoding.phpcodemania.com

การทำ Index ให้ MySQL Database เพื่อเพิ่มความเร็ว

สำหรับตัวอย่างนี้จะเป็นการ JOIN ตาราง 2 ตาราง 1. tb_reject_hd 2. tb_reject_desc ซึ่งจะเชื่อมกันด้วยฟิลด์ docno จะเห็นว่าเราสามารถคิวรี่เรียกข้อมูลออกมาได้ตอนที่ยังไม่ใส่ ORDER BY แต่เมื่อใส่ ORDER BY เข้าไป จะหมุนค้างจนหน้าเว็บหยุดทำงาน จากนั้นก็ลองเพิ่ม INDEX ให้กับฟิลด์ docno ในตาราง tb_reject_desc  ซึ่งในตัวอย่างนี้จะสร้างตารางใหม่ขึ้นมาจากตารางเดิม เปลี่ยนชื่อเป็น tb_reject_desc_with_index และทำการเพิ่ม INDEX KEY เข้าไป เมื่อทดสอบคิวรี่แบบมี ORDER BY จะเห็นว่าสามารถแสดงผลได้ทันที จากการสังเกตตัวเลขเวลาในการประมวลผล จะเห็นได้ว่าแบบไม่ใช้ ORDER BY จะทำงานเร็วกว่า แต่ในการทำงานส่วนใหญ่ก็มักจะต้องใช้ ORDER BY อย่างหลีกเลี่ยงไม่ได้ เช่นกรณีค้นหา แบบเรียงลำดับ ตัวอย่างโค้ดคิวรี่ข้อมูลจากตารางที่ Add Index Key แล้ว <!DOCTYPE html> <html lang="en"> <head>     <meta charset="UTF-8">     <title>Add Index Key</title> </head> <body> <h2>ORDER BY with ...

การสร้างเว็บไซต์ในปี 2023 นั้นจะต้องคำนึงถึงอะไรบ้าง

การสร้างเว็บไซต์ในปี 2023 นั้นจะต้องคำนึงถึงความเปลี่ยนแปลงของเทคโนโลยีและแนวโน้มการใช้งานของผู้ใช้ใหม่ๆ ดังนั้น นี่คือเทคนิคที่สามารถช่วยให้การสร้างเว็บไซต์ในปี 2023 เป็นไปได้อย่างรวดเร็วและเป็นประสิทธิภาพ: 1. ใช้ Responsive Design: การออกแบบเว็บไซต์ให้สามารถปรับขนาดได้ตามขนาดของหน้าจอของอุปกรณ์ต่างๆ เช่น โทรศัพท์มือถือ แท็บเล็ต และคอมพิวเตอร์ เพื่อให้ผู้ใช้สามารถเข้าถึงและใช้งานได้ง่ายและสะดวก 2. ใช้โครงสร้างของ HTML5: การใช้โครงสร้าง HTML5 จะช่วยให้เว็บไซต์ของคุณมีประสิทธิภาพและปรับปรุงในเรื่องของการเข้าถึงข้อมูล การใช้งานและความปลอดภัย 3. ใช้ CSS Grids หรือ Flexbox: การใช้ CSS Grids หรือ Flexbox จะช่วยให้ง่ายต่อการจัดหน้าเว็บไซต์ และสามารถปรับแต่งรูปแบบของเว็บไซต์ได้ง่ายขึ้น 4. ใช้ JavaScript Frameworks: การใช้ JavaScript Frameworks เช่น React, Angular, หรือ Vue.js จะช่วยให้สามารถสร้างเว็บไซต์ที่เป็น interactive และมีประสิทธิภาพได้อย่างรวดเร็ว 5. ใช้ Content Management Systems (CMS): การใช้ CMS เช่น WordPress, Joomla, หรือ Drupal จะช่วยให้สามารถสร้างเว็บไซต์ได้อย่างร PHP  C...

แจกโค้ด PHP : รวมลิงค์ แจกฟรี!! ตัวอย่างโปรเจ็กต์ ที่พัฒนาด้วย PHP

       สำหรับหลายท่านที่ขอโค้ดเข้ามาทาง Inbox ของเฟซบุ๊กแฟนเพจ หรือถามถึงระบบต่างๆหลังไมค์มานั้น ส่วนใหญ่ก็มีแจกอยู่แล้วในเว็บบอร์ด ThaiCreate.Com นะครับ  และด้านล่างนี้ก็เป็น Source Code PHP ระบบต่างๆ ที่มีเหล่าผู้ใจดีแจกฟรี!! ให้นำไปลองใช้ลองศึกษากันครับ แจกฟรี  !! ตัวอย่างการ  PHP  Booking # จองห้องประชุม  ผ่านเว็บครับ http://www.thaicreate.com/php/forum/090558.html ระบบแบบสอบถาม https://www.thaicreate.com/php/forum/099342.html แจก code!! การทำประเมินออนไลน์มี ไว้สำหรับพัฒนาต่อยอด https://www.thaicreate.com/php/forum/102203.html แจกฟรี PHP CodeIgniter CMS ให้ทุกท่านได้ลอง (รองรับ Responsive) http://www.thaicreate.com/php/forum/122929.html โดย : https://www.cszcms.com/ แจก PHP : ระบบยืม-คืนเอกสาร (จากตัวอย่าง เอกสารข้อมูลวัตถุดิบสินค้า) http://www.thaicreate.com/php/forum/103428.html แจกระบบ PHP Shopping Cart ระบบตะกร้าสินค้า ระบบสั่งซื้อ มีระบบตัดสต๊อก, สั่งซื้อวัตถุดิบคงเหลือ ht...

จัดระเบียบโค้ด ใน Notepad++ (Auto indentation plugin)

เวลาเขียนโค้ด แล้วไม่ได้จัดรูปแบบ หรือเอาโค้ดจาก Text Editor หนึ่งมาใช้ในอีกตัวหนึ่งก็มีโอกาสที่ Tab หรือ Space bar จะต่างกัน แล้วเราจะมานั่ง TAB เองก็คงไม่ไหว จึงจำเป็นต้องหา Plugin เข้ามาช่วย ลองค้นดูก็เจอกับกระทู้นี้ >> แม้หน้าตาจะไม่ตรงกันแต่หลักๆก็คือเพิ่ม Plugins เข้าไปชื่อ Indent By fold อ่านเต็มๆได้ที่นี่ https://softwarerecs.stackexchange.com/questions/1496/auto-indentation-plugin-for-notepad

PHP เบื้องต้น | รวมวิดีโอสอนเขียนโปรแกรม PHP & MySQL

1. พื้นฐาน PHP     1.1  โครงสร้างการเขียน PHP ร่วมกับ HTML     1 .2  Selection Structure : การเขียนโปรแกรมแบบทางเลือก     1. 3  ตัวแปร (Variable) และ ค่าคงที่ (Constant)     1.4  ตัวดำเนินการ (Operator)     1.5  เครื่องหมาย Single Quote / Double Quote และ Escape Sequence     1.6  Repetition Structure (การเขียนโปรแกรมวนซ้ำ)          1.7  การแทรกโค้ PHP ส่วนต่างๆของ HTML     1.8  PHP Function 2. PHP MySQLi CRUD : การจัดการฐานข้อมูล MySQL เบื้องต้น      2.1 : การบันทึกข้อมูลด้วย MySQLi Function      2.2 การค้นหาและแสดงข้อมูลในรูปแบบตาราง 1/2     2.3  การค้นหาและแสดงข้อมูลในรูปแบบตาราง 2/2      2. 4 การแก้ไขข้อมูลด้วยคำสั่ง UPDATE     2. 5 การลบข้อมูลจากฐานข้อมูล     2. 6 การป้องกัน SQL Injection ด้วยการใช้ prepare และ bindparam           2.7 กา...

PHP CI MANIA : ตอนที่ 12 การใช้งานระบบสมาชิกกำหนดสิทธิ์เข้าใช้งานด้วย Login SESSION

เริ่มจากการสร้างหน้าเว็บแบบไม่กำหนดสิทธิ์ และกำหนดสิทธิ์ให้ สมาชิกเท่านั้น ที่เข้าหน้าเว็บที่กำหนดได้     1. ทดลองสร้างหน้าเว็บแบบปกติ เมื่อกำหนดชื่อต่างๆเรียบร้อย ก็คลิกสร้างไฟล์ Models, Views, JS และ Controller ให้เรียบร้อย (สำหรับ Version 0.6 จะมีปุ่ม " สร้างไฟล์ทั้งหมด ")    2. จากนั้นคลิกลิงค์เพื่อดูตัวอย่าง(ในหน้า Controller) จะพบกับหน้าเว็บที่เราสร้างเอาไว้ จะเห็นว่า สามารถเข้าได้ปกติ     3. สลับไปที่หน้า "ตั้งค่า" และคลิกเลือก "Login Require" เพื่อกำหนดว่า จะเข้าหน้าเว็บนี้ได้ จะต้องผ่านการ Login ก่อนเท่านั้น จากนั้นก็คลิกสร้างไฟล์ Models, Views, JS และ Controller ให้เรียบร้อย (สำหรับ Version 0.6 จะมีปุ่ม " สร้างไฟล์ทั้งหมด ")    4. จากนั้นคลิกลิงค์เพื่อดูตัวอย่าง(ในหน้า Controller) จะพบกับหน้าเว็บที่ ต้อง Login ก่อน จึงจะสามารถเข้าใช้งานได้    สำหรับ รหัสที่ใช้ทดสอบ นั้นได้กำหนดค่าเบื้องต้นไว้ให้ดังนี้    - Admin     ใช้ชื่อล็อกอิน admin รหัสผ่าน 123456     -...

วิธีแก้ไข JavaScript โดยไม่ต้อง Refresh หน้าเว็บใหม่

แก้ไข JavaScript โดยไม่ต้อง Refresh เป็นปกติทุกครั้งที่แก้ไขโค้ด JavaScript เราจำเป็นจะต้องรีเฟรชหน้าเว็บใหม่ทุกครั้ง แต่วันนี้ผมจะมาแนะนำวิธีรัน JavaScript ให้พร้อมใช้งานโดยไม่ต้องโหลดหน้าเว็บใหม่มาแนะนำครับ (สำหรับกรณีที่กำลังป้อนข้อมูลแบบฟอร์ม แล้วไม่อยากป้อนใหม่ เวลาที่ JavaScript error) ( แก้ปัญหาเวลาแก้ไข JavaScrip, CSS อัพขึ้นโฮสต์แล้วต้องกด CTRL + F5 เพื่อโหลดไฟล์ใหม่ทุกครั้ง ) ปัญหาเริ่มจากกดปุ่มลบ แล้ว Page not found  (หรือกรณี Event ใดๆ ที่กดปุ่มแล้ว JavaScript ไม่ทำงาน) ลองตรวจสอบ URL ที่ส่งไปเป็น / remove_price ซึ่งเกิดจากการระบุในไฟล์ JavaScript ไม่ตรงกับหน้าเว็บ เมื่อเปิดไปที่ไฟล์ PHP ในหน้าเว็บสำหรับลบราคา ปรากฏว่า URL ที่ถูกต้องคือต้องลงท้ายด้วย / removePrice ดังนั้นก็ต้องกลับไปทำการแก้ไขในไฟล์ .js ให้เป็น URL ที่ถูกต้อง  แต่ JavaScript เมื่อแก้ไขเสร็จเราจะต้อง Refresh หน้าเว็บเพื่อโหลดสคริปต์ใหม่ ซึ่งบางทีเราก็แก้ไขแค่จุดเดียว หากไม่อยากเสียเวลาโหลดใหม่ เราก็คัดลอกโค้ดเฉพาะ Function ที่เราแก้ไข เอาไปรันใน...

SELECT ซ้อน SELECT (GROUP BY, HAVING, SUBQuery, COUNT)

เมื่อต้องการนับจำนวนรายการตามเงื่อนไข แต่ก็จำเป็นต้องใช้ GROUP BY เพราะการใช้ COUNT + DISTINCT ไม่สามารถดึงข้อมูลตามเงื่อนไขได้  อยากจะนับจำนวนสมาชิกที่ชำร ะเงิน ถ้าใช้ COUNT() ก็จะออกมาหมด ทำให้ได้จำนวนเกินจากความเป ็นจริง เพราะสมาชิกบางคนชำระมากกว่ า 1 ครั้ง ก็เลยต้องเอามา GROUP กันด้วย รหัสสมาชิกก่อน เพื่อตัดเรคอร์ดที่ซ้ำกันออ กไป สมาชิกจะชำระกี่ครั้ง ก็นับเป็น 1 คน (เพราะเป็นสมาชิกคนเดียวกัน ) จะเห็นว่า จะได้ยอดที่ถูกต้อง 139 แต่ข้อมูลมันแจกแจงรายการต้ อง 139 แถว ซึ่งเราไม่ได้อยากได้รายละเ อียด แค่อยากนับจำนวนเท่านั้นจะท ำไงล่ะทีนี้ ก็จัดการ SELECT ครอบ SELECT ไว้เลย ซึ่งก็คือการทำ SubQuery นั่นเอง ก็จะออกมาเรคอร์ดเดียว เป็นจำนวนที่ต้องการนำไปใช้ งานได้ทันที จริงๆแล้วเราใช้ DISTINCT ได้นะ ถ้าเงื่อนไขมีแค่เท่านี้ ไม่จำเป็นต้อง SubQuery ดูสิ พอนับแบบตัดรายการซ้ำกันออก ก็ได้ 139 พอดิบพอดีเลย ใช่ครับ ถ้าเงื่อนไขมีเพียงเท่านี้ก ็ใช้ได้เลย แต่ถ้ามีเงื่อนไขอื่นล่ะ??? ถ้าจะนับเฉพาะสมาชิกที่ชำระ เงินตั้งแต่ 150...

MySQL คำสั่ง SQL จัดเรียงคำตามตัวอักษร ภาษาไทย ในฟิลด์ที่กำหนด Collation เป็น utf-8

การจัดเรียงข้อมูลตามลำดับตัวอักษรไทย   CONVERT( name USING tis620 ) ASC การเรียงลำดับตัวอักษรแบบ tis-620 ในการเขียนโปรแกรม PHP เพื่อแสดงข้อมูลจากฐานข้อมูล MySQL การเขียนคำสั่ง SQL ให้จัดเรียงลำดับนั้น เราจะใช้ ORDER BY  และกำหนดฟิลด์ที่ต้องการจัดเรียงลำดับ เช่น ในตัวอย่างนี้จะเป็นการจัดเรียงตามลำดับตัวอักษรของชื่อเมนู นั่นก็คือฟิลด์ name นั่นเอง แต่ในขั้นตอนการสร้างฐานข้อมูลนั้น เราได้กำหนด Charset ของตารางและฟิลด์เป็นการจัดเรียง Collation แบบ utf-8 เอาไว้เพื่อให้รองรับภาษาแบบมาตรฐาน ดังนั้นเมื่อเขียนโปรแกรมสั่ง ORDER BY name ASC ก็จะมีการจัดเรียงที่จะให้คำที่มีสระนำหน้าอยู่หลัง ฮ. นกฮุก ไปเสียหมด จะเห็นว่าชื่อเมนูหรือสินค้าที่มี ข นำหน้าจะมาเป็นลำดับแรก ทั้งที่จริงๆแล้ว มีสินค้าที่เป็น ก อยู่หลายรายการ เพียงแต่ว่ามีสระนำหน้าอยู่เท่านั้นเอง จากรูปด้านบน จะมีรายการที่เป็น ก อยู่ 3 รายการ คือเมนู โกโก้ ต่างๆ แต่เพราะมีสระโอ นำหน้า จึงทำให้การจัดเรียงแบบ utf-8 ให้อยู่ในลำดับท้าย เพื่อแก้ไขปัญหานี้ การเขียนโปรแกรมเพื่อ ORDER BY จะต้...

ค้นหาบล็อกนี้