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

บทความ

กำลังแสดงโพสต์จาก สิงหาคม, 2018

SyntaxError: JSON.parse: unexpected non-whitespace character after JSON data

วิธีแก้ปัญหา SyntaxError: JSON.parse: unexpected non-whitespace character ปัญหาที่เกิดขึ้นคือ เมื่อมีการ submit ผ่าน iframe และให้ PHP คืนค่าเป็น JSON $json = json_encode(array(                                     "is_successful" => FALSE,                                     "message" => $message )); echo $json; ผลที่ได้คือ หน้าเว็บค้าง ไม่มีอะไรตอบสนองหรือทำงานต่อจากนั้นเลย และเมื่อเปิด console ขึ้นมาดูก็พบข้อความแจ้ง error ดังนี้ SyntaxError: JSON.parse: unexpected non-whitespace character after JSON data at line 1 column 921 of the JSON data ทั้งที่ค่าคืนกลับมาใน iframe ก็ปกติดี โค้ดในส่วนของการดึงข้อมูลใน iframe หลังจาก Submit เรียบร้อยมีดังนี้ var c = 0; $("#post_iframe").on('load',function() { c++; if(c==1){ iframeContents = this.contentWindow.document.body.innerHTML; var...

PHP CI MANIA : PHP CodeIgniter Generator โปรแกรมช่วยสร้างโค้ด ลดเวลาการเขียนโปรแกรม

ราคาแต่ละเวอร์ชั่น   (ราคา 1,500 .- / 2,990.- / 3,990 .-)        จะเริ่มที่เวอร์ชั่น 0.1 ถึง 0.9 โดยความสามารถเริ่มต้นคือ        1) หน้าแสดงรายการทั้งหมด จะสามารถค้นหา และแบ่งหน้าได้อัตโนมัติ        2) หน้าเพิ่มข้อมูล จะสามารถกำหนดจำนวน INPUT ที่ต้องการป้อนข้อมูลได้        3) หน้าแสดงรายละเอียดเรคอร์ด สามารถคลิกเลือกรายการที่ต้องการดูข้อมูลทั้งหมดได้        4) หน้าแก้ไขข้อมูล สามารถคลิกแก้ไขข้อมูลในแต่ละเรคอร์ดจากหน้าแสดงรายการได้        5) การลบข้อมูล สามารถคลิกลบรายการในแต่ละเรคอร์ดได้        6) มีระบบ Login และบริหารจัดการข้อมูลสมาชิกได้        นอกจากนี้ระบบยังรองรับส่วนของการ JOIN TABLE อื่นๆได้อีกด้วย เช่น ฟิลด์ที่เก็บรหัสสมาชิก จะสามารถ JOIN ไปยังตารางสมาชิก เพื่อดึงชื่อมาแสดงผลได้ด้วย        และความสามารถอีกอย่างที่จำเป็นอย่างยิ่งนั่นก็คือ รองรับการเชื่อมโยงกับตา...

K Plus จ่ายค่าไฟฟ้าส่วนภูมิภาค ผ่านแอพฯ PEA Smart Plus

การทำงานร่วมกันของ PEA Samrt Plus กับ K PLUS - ธนาคารกสิกรไทย หลังจากที่พยายามหาเมนูจ่ายค่าไฟ(การไฟฟ้าส่วนภูมิภาค) อยู่หลายครั้งหลายหน พยายามจ่ายด้วยเมนู การไฟฟ้านครหลวง อยู่หลายครั้งก็ไม่สำเร็จ (จะจ่ายได้ไงเล่า มันคนละส่วนกันกับการไฟฟ้าส่วนภูมิภาค) ก็ลองค้นหาใน Google และเลื่อนไปเปิดกระทู้พันทิปมาอ่าน ก็ได้ความว่า ต้องติดตั้งแอพ PEA Samrt Plus ก่อนจึงจะสามารถชำระเงินได้ หลังจากติดตั้งเรียบร้อย เปิดขึ้นมาก็จะเจอส่วนของการลงทะเบียน เมื่อลงทะเบียนเรียบร้อยก็มาเพิ่มสถานที่ใช้ไฟฟ้า - จะแสกน QR Code/Barcode - หรือ จะกรอกเองตามตัวอย่างบนบิลค่าไฟก็ได้ กรอกข้อมูลเรียบร้อยให้สังเกตข้อมูลชื่อเจ้าของผู้ใช้ และยอดค้างชำระว่าถูกต้องหรือไม่ ถ้าถูกต้องกดที่เข้าไปเพื่อชำระค่าไฟค้างจ่าย หรือจะเข้าไปที่เมนู ชำระค่าไฟฟ้า ด้านล่างก็ได้ ถ้ามีค่าไฟฟ้าค้างจ่าย จะปรากฏกลางจอภาพให้เลือก (แต่ในภาพด้านล่างนี้ชำระไปแล้วก็เลยว่างเป่า) เมื่อกดเลือกรายการที่ต้องการชำระเรียบร้อย ให้เลือก บัญชีธนาคาร หลังจากกดเลือกบัญชีธนาคารแล้ว จะมีรายชื่อธนาคารให้เลือก - ...

ตัวอย่างการใช้ HTML5 Canvas วาด ER Diagram

มาดูตัวอย่างการใช้ Canvas วาด ER Diagram กันครับ ถ้าดูในโค้ดด้านล่างนี้ จะสังเกตเห็นว่าส่วนของ //LEFT หรือตาราง Master และส่วนของ //RIGHT หรือตาราง Detail ทั้งสองส่วนนี้ จะทำงานซ้ำๆกัน ซึ่งถ้านำไปใช้จริงก็จะเป็นการดึงฟิลด์ของตารางที่เกี่ยวข้องออกมาวนลูป เพื่อแสดงชื่อฟิลด์ในช่องแต่ละช่อง ตามจำนวนฟิลด์ที่มีในตารางแต่ละตาราง ตัวอย่างโค้ดวาด ER Diagram <!DOCTYPE HTML> <html>   <head>     <style>       body {         margin: 0px;         padding: 0px; background-color : #eeeeee; text-align : center;       } canvas#myCanvas{ border: 1px solid #cccccc; background-color : #ffffff; }     </style>   </head>   <body>     <canvas id="myCanvas" width="1024" height="600"></canvas>     <script> var canvas = document.getElementById('myCanvas'); var context = canvas.getConte...

Bootstrap Flowchart - สร้างโฟลวชาร์ตระบบแบบง่ายๆ

Bootstrap Determination Flowchart ตัวอย่างการทำโฟลชาร์ตแบบง่ายๆ ด้วย Bootstrap Frmaework ซึ่งน่าจะนำไปใช้ประโยชน์ต่อการสร้างระบบจัดการโปรเจ็กต์ของเราได้ และสิ่งที่น่าสนใจอีกอย่างคือ เมื่อนำไปเชื่อมโยงกับระบบ CodeIgniter Generator ที่ผมกำลังสร้างมานั้น อาจจะสามารถสร้างระบบการจัดการโปรเจ็กต์พร้อมสร้างโครงสร้างไฟล์ที่จำเป็นได้เสร็จสรรพ ที่มา : https://bootsnipp.com/snippets/a36yo PHP  CI  MANIA   -  PHP Code Generator  โปรแกรมช่วยสร้างโค้ด ลดเวลาการเขียนโปรแกรม เขียนโปรแกรมง่ายและสะดวกขึ้น สนใจสั่งซื้อราคาสุดคุ้ม >>  http://fastcoding.phpcodemania.com/

PHP จัดตารางการแข่งขันฟุตบอล / บาสเกตบอล / กีฬาประเภทพบกันทุกทีมเหย้า-เยือน

PHP generate football schedule ในโค้ดตัวอย่างด้านล่างนี้ จะเป็นการวนลูป for อยู่ด้วยกันทั้งหมด 3 รอบ for ครั้งที่ 1  กำหนดให้นับแค่ 2  ในลูปแรกจะเป็นทีมเหย้า ในลูปที่สองจะเป็นทีมเยือน for ครั้งที่ 2 จะนับตามจำนวนทีม ในตัวอย่างมี 8 ทีมก็จะนับจนกว่าจะครบ 8 ทีม for ครั้งที่ 3 จะนับตามจำนวนทีมคู่แข่ง ในตัวอย่างมี 8 ทีม ก็จะพบคู่แข่งอีก 7 ทีม  (ซึ่งพบกัน 2 ครั้ง เหย้า-เยือน ก็จะเท่ากับ 14 ครั้ง) ข้อสังเกต เมื่อขึ้น Day 9 จะมีการสลับเอาทีมเยือนขึ้นมาเป็นทีมเหย้า Team 2 จึงเป็นเจ้าบ้านรับการมาเยือนของ Team 1 แทน สำหรับโค้ดที่ใช้เป็นตัวอย่าง มีดังต่อไปนี้ [PHP CODE] <?php $teams = array( 'Team 1', 'Team 2', 'Team 3', 'Team 4', 'Team 5', 'Team 6', 'Team 7', 'Team 8' ); $team_logo[0] = 'https://cdn4.iconfinder.com/data/icons/pokemon-go/512/Pokemon_Go-15-512.png'; $team_logo[1] = 'https://cdn4.iconfinder.com/data/icons/pokemon-go/512/Pokemon_Go-16-512.png';...

JavaScript เปลี่ยนตัวพิมพ์ใหญ่ให้กับอักษรตัวแรกเหมือน ucfirst() ของ PHP

JavaScript กับการกำหนดตัวแรกเป็นตัวพิมพ์ใหญ่ สร้างฟังก์ชั่น JavaScript เพื่อทำให้ตัวแรกเป็นตัวพิมพ์ใหญ่ function jsUcfirst(string)  {      return string.charAt(0).toUpperCase() + string.slice(1); } วิธีการเรียกใช้งาน <input name="controller_name" onchange="this.value=jsUcfirst(this.value)" /> โค้ดด้านบนนี้จะทำงานเมื่อเกิดการเปลี่ยนแปลงข้อมูลในช่องกรอกข้อมูลที่ชื่อ controller_name จะเรียก onchage ขึ้นมาทำงาน this.value=jsUcfirst(this.value) คือคำสั่ง JavaScript ที่กำหนดให้ค่า value ของช่องกรอกข้อมูลตัวนี้ มีค่าเท่ากับค่าที่เปลี่ยนตัวแรก เป็นตัวพิมพ์ใหญ่ไปแล้ว มาดูกันทีละขั้นตอนว่าเกิดอะไรขึ้นบ้างในฟังก์ชั่นนี้ เราจะสามารถแยกออกได้ 3 เหตุการณ์ด้วยกัน คือ เหตุการณ์ที่ 1 => string.charAt(0) เหตุการณ์ที่ 2 => .toUpperCase() เหตุการณ์ที่ 3 => + string.slice(1); สมมติว่าเราส่งคำว่า members เข้าไปในฟังก์ชั่น jsUcfirst() string.charAt(0) จะทำการตัดอักษรตัวแรกออกมาจาก string จะได้คำว่า m ออกมา .toUpperCase() จะทำงานต่อทันทีหลังจาก...

มันเป็นเรื่องของเหตุผล ที่เมื่อผลลัพธ์ Callback มาแล้วไม่มีฟังก์ชั่นไหน Validate สิ่งที่ได้รับกลับมาเท่านั้นเอง

+++ ทำความดีควรหวังผล แต่ไม่ต้องหวังสิ่งตอบแทน +++ ผมอาจจะจั่วหัวดูชวนสงสัยกันสักหน่อย เพราะเรามักจะได้ยินคำว่า  " ทำดีไม่หวังผลตอบแทน " ผมก็แค่เติมคำใหม่เข้าไปว่า ควรหวังผล เพราะถ้าเราไม่หวังผล แล้วเราจะรู้ได้อย่างไรว่าสิ่งที่ทำลงไป "นั้นดีจริง" บุญ นั้นเกี่ยวข้องกับเรื่องของ เหตุ และ ผลแห่งกรรม กับคำถามที่ว่า  ทำบุญหวังผลตอบแทนจะไม่ได้บุญจริงหรือ??? ว่าด้วยเรื่องของ เหตุและผล เมื่อเราทำลงไปแล้ว ต่อให้อยากได้หรือไม่อยากได้ ผลจากสิ่งที่เราทำไปแล้วนั้น ย่อมกลับมาหาเราแน่นอน ไม่ทางใดก็ทางหนึ่ง ดังนั้น เมื่อเราทำบุญ เราย่อมได้บุญแน่นอน  ไม่ว่าเราจะอยากได้หรือไม่อยากได้ก็ตาม แต่คำถามที่ควรถามจริงๆคือ ผลบุญที่เราอยากได้นั้นใช่ผลบุญที่ได้รับจริงหรือไม่? "เราคงไม่อาจหาฟังก์ชั่นไหนใช้ Validate สิ่งที่ Callback กลับมาได้" มันก็เหมือนกับเราขยันอ่านหนังสือสอบ เราก็จะสอบได้เกรดดีๆ ตามที่เราหวังไว้ นี่ก็คืออีกหนึ่งการสร้างบุญของวัยเรียน มันคือสิ่งดีๆที่เราทำให้ตัวเอง และพ่อแม่ได้ชื่นใจ ดั...

รวบรวมข้อมูลสำหรับสร้าง เครื่องผสมเมนูเครื่องดื่มอัตโนมัติ - ชงกาแฟอัตโนมัติ

แนวคิดจากคลิปวิดีโอ เครื่องกดน้ำอัดลม DIY ไอเดียสำหรับต่อยอด สร้างวงจรควบคุมระยะเวลาปั๊มด้วยการจ่ายไฟผ่านระบบ ไมโครคอนโทรลเลอร์ (Micro Controller) เพื่อเลือกเมนูแต่ละเมนู ที่กำหนดระยะเวลาของการจ่ายไฟให้ปั๊มแต่ละตัวต่างกัน และกำหนดระดับความหวานได้หลายระดับ ซึ่งแต่ละระดับก็จะมีระยะเวลาการจ่ายไฟที่ต่างกัน ตัวอย่าง ขา 1 = ปั๊มจ่ายน้ำเชื่อม ขา 2 = ปัมจ่ายนมสด ขา 3 = ปั๊มจ่ายนมข้นหวาน ขา 4 = บลูฮาวาย ขา 5 = แคนตาลูป หวานระดับ 1 ขา 1 จ่ายไฟออกหน่วงเวลา 3 วินาที หวานระดับ 2 ขา 1 จ่ายไฟออกหน่วงเวลา 5 วินาที หวานระดับ 3   ขา 1 จ่ายไฟออกหน่วงเวลา 7 วินาที หวานระดับ 4   ขา 1 จ่ายไฟออกหน่วงเวลา 9 วินาที หวานระดับ 5   ขา 1 จ่ายไฟออกหน่วงเวลา 12 วินาที เมื่อเราจ่ายไฟไปยังปั๊มที่การหน่วงเวลาต่างกัน ระยะเวลาที่ปั๊มทำงานก็จะต่างกัน ซึ่งปริมาณน้ำเชื่อมที่ได้ของแต่ละระดับก็จะต่างกันไป และเมื่อเลือกเมนูอะไรไว้ ปั๊มที่เลือกไว้ก็จะทำงานตามระยะเวลาที่กำหนด และเมื่อครบตามจำนวนปั๊ม ก็จ่ายไฟเลี้ยงไปยังเครื่องผสมเครื่องดื่ม Self Stirring Mug ...

PHP MOD การหารเอาเศษ การคิดราคาสินค้าแบบแพ็ก แบบชิ้น

การคิดราคาสินค้าแบบแพ็ก    หลักการเบื้องต้นก็คือ 1. คิดราคาแบบเป็นแพ็ก $pack_buy = floor($customer_buy / $product_xx_pack_qty); //ปัดเศษทิ้ง $total_pack_buy_price = $pack_buy * $product_xx_pack_price;//คิดราคาแบบ pack ใน PHP เราจะใช้ฟังก์ชั่น floor() เพื่อปัดเศษทิ้ง เอาเฉพาะที่ครบจำนวนแพ็กเพื่อไปคูณกับราคาต่อแพ็ก แต่ถ้าไม่ครบก็จะนำไปคำนวณราคาต่อแพ็กแล้วได้ 0 2. หาราคาต่อชิ้น ที่เหลือจากการหารเพื่อหาแบบแพ็ก $piece_buy = $customer_buy % $product_xx_pack_qty;//หารแบบเอาเศษ $piece_price = $piece_buy * $product_xx_price;// ราคาของส่วนที่เหลือจากแพ็ก     แน่นอนว่าถ้าซื้อไม่ถึงแพ็ก ก็จะเป็นจำนวนชิ้นทั้งหมด  แต่ถ้าซื้อครบแพ็กพอดี จำนวนชิ้น ก็จะเป็น 0 เพราะคิดราคาแบบแพ็กเท่านั้น แต่ถ้าซื้อเกินแพ็กเศษเท่าไหร่ก็เอาไปคูณกับราคาต่อชิ้น

PHP เปรียบเทียบวันที่ หาผลต่างระหว่างวันที่ 2 วัน ด้วยฟังก์ชั่น DateTime

ในตัวอย่างนี้ เราจะหาผลต่างระหว่างวันที่ 2 วันด้วยฟังก์ชั่น PHP DateTime Class ซึ่งจะมีให้เรียกใช้ตั้งแต่ PHP เวอร์ชั่น  5.2.0 ขึ้นไป กำหนดให้ตัวแปร PHP ชื่อ $date1 และ $date2 รับค่าจากการส่งค่าแบบฟอร์มแบบ POST โดยจะใช้ isset() ตรวจสอบค่าก่อนว่าได้ส่งมาหรือไม่ ถ้ายังไม่ได้ส่งค่าจากแบบฟอร์มมา จะเซ็ตให้เป็นค่าว่าง เพราะกรณีเปิดหน้าเว็บขึ้นมา จะยังไม่ได้ส่งค่าใดๆ เมื่อได้ค่าจากแบบฟอร์มเราจะเรียกคลาส DateTime() ใน PHP คำนวณค่าให้ด้วยเมธอด/ฟังก์ชั่น diff() จากนั้นก็เซ็ต format() ให้อยู่ในรูปแบบที่ต้องการ ซึ่งอ่านเพิ่มเติมเกี่ยวกับรูปแบบได้ที่ Supported Date and Time Formats http://php.net/manual/en/datetime.formats.php สำหรับซอร์สโค้ด PHP ที่ใช้ทั้งหมดมีดังตัวอย่างต่อไปนี้ [ PHP Code ] <?php $date1 = isset($_POST['date1']) ? $_POST['date1'] : ''; $date2 = isset($_POST['date2']) ? $_POST['date2'] : ''; $datetime1 = new DateTime($date1); $datetime2 = new DateTime($date2); $interval = $datetime1->diff($dateti...

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

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

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

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 จะต้...

PHP ระบบบริหารจัดการ พล็อตนิยาย - ตอนที่ 1

PHP Fiction Management System   โปรเจ็กต์นี้จะสร้างเป็น "ระบบบริหารจัดการพล็อตนิยาย" แบบง่ายๆ มาเล่าสู่กันฟังครับ มีอยู่ช่วงหนึ่งที่ผมสนใจการเขียนนิยาย และค้นหาข้อมูลเพิ่มเติมเกี่ยวกับการเขียนนิยาย และได้พบกับโปรแกรมหนึ่งที่ช่วยงานด้านการเขียนนิยายให้เป็นเรื่องที่ง่ายขึ้น แต่จากที่ได้อ่านรีวิวแล้วดูเหมือนว่า โปรแกรมช่วยเขียนนิยายนี้ ไม่จะไม่ค่อยรองรับภาษาไทย แต่ผมก็ยังไม่ได้ลองมาดาวน์โหลดมาลองใช้งานดูนะครับ แต่รู้สึกชอบเครื่องมือนี้ เลยอยากลองพัฒนาโดยถอดคุณสมบัติพื้นฐานมาใช้งานดู ว่าจะใช้กับงานเขียนนิยายได้จริงรึเปล่า ตัวอย่างระบบจัดการพล็อตเรื่อง เพื่อช่วยงานเขียนนิยาย หลังจากที่ได้นั่งคิดนอนคิด และหลับไปฝันไป จนในที่สุดก็ได้ฐานข้อมูลระบบบริหารจัดการพล็อตนิยายมาคร่าวๆ มาจนได้ โครงสร้างฐานข้อมูลตอนนี้อาจจะขี้เหร่ไปบ้าง แต่ในอนาคตก็คงจะพัฒนากันต่อไป   ตารางที่จะต้องสร้าง มีทั้งหมด ดังนี้ 1. รายชื่อนิยายทั้งหมด 2. แนวนิยายที่เขียน 3. พล็อตของแต่ละเรื่อง 4. ฉากเหตุการณ์ในแต่ละพล็อต 5. เนื้อเรื่องในแต่ละฉาก 6. รายชื่อตัวละครในนิยา...

CodeIgniter PDF ตอนที่ 2 : กรอกข้อมูลลงในแบบฟอร์ม PDF

      จากความเดิมตอนที่แล้ว " PHP PDF ตอนที่ 1 : ออกรายงานเอกสาร PDF ด้วย PHP CodeIgniter โดยใช้ไลบรารี่ TCPDF และ FPD " ในตอนนี้เรามาลองสร้างข้อมูลทดสอบกันสักหน้าละกันนะครับ ก่อนที่จะนำเข้าสู่การสร้างฐานข้อมูลเพื่อใช้กับข้อมูลทะเบียนนักเรียนของเรา และจะต่อยอดไปถึงระบบบันทึกข้อมูลผลการประเมินแบบออนไลน์กันเลยทีเดียว ^^ 1. เริ่มต้นจากการเตรียมไลบราลี่ PDF ที่ต้องใช้ทั้งหมด 2 ตัวด้วยกัน     1) TCPDF     2) FPDI     (จะนำไปไว้ในไดเรกทอรี่ application/third_party ของ codeigniter) 2. จากนั้นก็เตรียมโปรเจ็กต์ด้วย CodeIgniter ด้วยโปรแกรมที่ใช้เขียนโค๊ด (IDE) ที่ชื่อว่า eclipse ซึ่งในส่วนนี้ใครถนัดโปรแกรมไหน จะใช้อะไรเขียนโค๊ดก็ตามสะดวกเลยครับ 3. สร้างไฟล์ Pdf.php ในไดเรกทอรี่ libralies เพื่อเรียกใช้ไลบราลี่ TCPDF และ FPDI    libraries/Pfd.php <?php if ( ! defined('BASEPATH')) exit('No direct script access allowed'); require_once APPPATH.'third_party/tcpdf/tcpdf.php'; require_once ...

ออกแบบระบบ Login อย่างง่ายด้วย CodeIgniter Framework

โครงสร้างการจัดวางไฟล์ application/ ├── controllers/ │   └── Member_login.php ├── models/ │   └── Member_login_model.php ├── views/ │   └── member_login/ │       └── login_view.php ส่วนของฟอร์ม HTML ( View ) <div class="container"> <h2>Login</h2> <?php if($this->session->flashdata('error_message')): ?> <div class="alert alert-danger"> <?php echo $this->session->flashdata('error_message'); ?> </div> <?php endif; ?> <?php echo form_open('member_login/login'); ?> <div class="form-group"> <label for="username">Username:</label> <input type="text" class="form-control" id="username" name="username"> </div> <div class="form-group"> <label for="password">Password:</label> <input type="password" class=...

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

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

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