mysqli_set_charset()
ใน PHP เชื่อว่าหลายคนอาจจะเคยเจอปัญหา โปรแกรมไม่รองรับภาษาไทยบ้าง หรือ ภาษาอื่นๆ เหตุผลส่วนเพราะว่าเราไม่ได้ตั้งค่าชุดอักขระไว้ สำหรับภาษาไทยเรามักจะใช้เป็น UTF8 ครับ เรามาดูฟังก์ชัน mysqli_set_charset ว่าคืออะไรและทำงานกันอย่างไร
mysqli_set_charset - ตั้งค่าชุดอักขระไคลเอนต์เริ่มต้น ค่าชุดอักขระเริ่มต้นที่ตั้งค่าไว้จะใช้เมื่อส่งข้อมูลจากและไปยังเซิร์ฟเวอร์ฐานข้อมูล
รูปแบบ Syntax ดังนี้
mysqli_set_charset ( mysqli $link , string $charset ) : bool
link
: รูปแบบขั้นตอนเท่านั้น: ตัวระบุลิงก์ที่ส่งคืนโดยฟังก์ชัน mysqli_connect() หรือ mysqli_init()
charset
: ชุดอักขระที่จะตั้งเป็นค่าเริ่มต้น
ตัวอย่างการใช้งานดังนี้
$link = mysqli_connect("ชื่อโฮส","ชื่อผู้ใช้","รหัสผ่าน");
$connDB = mysqli_select_db($link,"ชื่อฐานข้อมูล");
mysqli_set_charset($link,'utf8'); //กำหนดการแสดงผลภาษาไทย
หรือ ตัวอย่างอื่นๆดังนี้
<?php
$link = mysqli_connect('localhost', 'my_user', 'my_password', 'test');
/* check connection */
if (mysqli_connect_errno()) {
printf("Connect failed: %s\n", mysqli_connect_error());
exit();
}
printf("Initial character set: %s\n", mysqli_character_set_name($link));
/* change character set to utf8 */
if (!mysqli_set_charset($link, "utf8")) {
printf("Error loading character set utf8: %s\n", mysqli_error($link));
exit();
} else {
printf("Current character set: %s\n", mysqli_character_set_name($link));
}
mysqli_close($link);
?>
ผลลัพธ์ที่ได้
Initial character set: latin1
Current character set: utf8
อย่างที่เราทราบกันอยู่แล้วว่าตั้งแต่ MySQL เวอร์ชั่น 4.x หรือ 5.x ขึ้นไปจะให้ความสำคัญกับ Collation ของ Charset มาก โดยตัว Collation นี่เองจะเป็นระบุชนิดของข้อมูล Charset ที่จะจัดเก็บ ซึ่งเป็นกระบวนการบน Database ของ MySQL ที่จะจัดการกับข้อมูลนั้น ๆ และสำหรับ Collation ที่ได้รับความนิยมมากที่สุดก็คือ utf8 เพราะมันสามารถรองรับการจัดเก็บได้หลากหลายภาษา ไม่จำกัดเฉพาะภาษาไทยเท่านั้น โดยข้อมูลจะถูกจัดเก็บในรูปแบบของ Character encoding คือ ทุก Character จะผ่านการแปลงก่อนการจัดเก็บ และ ค่อยแปลงกลับก่อนนำมาใช้ ฉะนั้นมันจะสามารถปัญหาเรื่องภาษาไทยและภาาาอื่น ๆ ได้อย่างแม่นยำไม่ผิดเพี้ยนแน่นอน