หน้าแรก เขียนใบสมัครงาน ลงโฆษณางาน ค้นหาใบสมัครงาน คู่มือการใช้งาน Menu

สนใจลงโฆษณา โทร. 02-275-1900, 02-612-4900, 038-395000

space
   ค้นบ่อย : หางานบัญชี, หางานธุรการ, หางานจัดซื้อ, หางานผู้จัดการ, หางานขับรถ, หางานบุคคล, หางานคลังสินค้า, หางานครู, หางานวิศวกร, หางานเขียนแบบ, หางานคีย์ข้อมูล, หางานการตลาด, หางานโรงแรม, หางานสิ่งแวดล้อม, หางานคอมพิวเตอร์, หางาน Programmer, หางานประชาสัมพันธ์, หางานช่าง, หางานสถาปนิก
เรื่อง การแสดงผลภาษาไทยเป็น ?????
เขียนโดย itgirl

Rated: vote
by 3 users

คุณคิดอย่างไรกับเรื่องนี้?

 




เมื่อภาษาไทยกลายเป็น ?????????

คัดลอกจาก http://www.phpconcept.com/ เพิ่มเติมบางส่วนโดย อดิศร  ขาวสังข์

ผมเคยติดตั้งและใช้งาน PHP และ MySQL มาหลายครั้งหลายหน ไม่ว่าจะเป็นการติดตั้งบน Linux หรือ Windows ทั้งที่ Compile เองและติดตั้งแบบ package  ซึ่งการติดตั้งบน Windows ดูจะติดตั้งอย่างสะดวกและรวดเร็วมากขึ้น เพราะมีผู้ทำโปรแกรมช่วยติดตั้ง Apache PHP และ MySQL อัตโนมัติ เช่น AppServ (www.appservnetwork.com) และ XAMPP (http://www.apachefriends.org/en/index.html) เป็นต้น

แต่คราวนี้ผมเจอปัญหาหลังจากการติดตั้ง Apache PHP และ MySQL บนระบบปฏิบัติการ Windows เพราะเมื่อทดลอง query ข้อมูลที่เป็นภาษาไทยจาก MySQL กลับพบว่าได้ผลลัพธ์ในการแสดงผลภาษาไทยที่ไม่ถูกต้อง คือตัวอักษรภาษาไทยจะแสดงออกมาเป็นเครื่องหมายคำถาม (?) ทั้งหมด ในขณะที่ผมได้เพิ่ม option ที่เกี่ยวกับการ set character ให้เป็นภาษาไทยใน my.ini แล้ว ดังตัวอย่างต่อไปนี้

[mysqld]
default-character-set=tis620

หลังจากที่ได้ทำการตรวจสอบแล้วในฐานข้อมูล MySQL โดยใช้โปรแกรม เช่น MySQL-Front (http://www.mysqlfront.de/) แล้วก็พบว่าข้อมูลที่เก็บอยู่ก็เป็นภาษาไทยถูกต้อง และเมื่อลองดูตัวแปรต่างๆ ที่เกี่ยวข้องกับ character ต่างๆ ก็พบค่าต่อไปนี้

- character_set_client = tis620
- character_set_connection = tis620
- character_set_database = tis620
- character_set_results = tis620
- character_set_server = tis620
- character_set_system = utf8
- collation_connection = tis620_thai_ci
- collation_database = tis620_thai_ci
- collation_server = tis620_thai_ci

เมื่อลองไปค้นในเว็บไซท์ของ MySQL ในส่วนที่เกี่ยวข้องกับกลุ่มอักขระ (character set) ก็พบส่วนที่เกี่ยวข้องกับกลุ่มอักขระ ใน Chapter 10. Character Set Support (http://dev.mysql.com/doc/mysql/en/charset.html) ซึ่งได้อธิบายความหมายของ Character set ไว้ว่าคือ กลุ่มของสัญลักษณ์และการ encode อักขระต่างๆ ส่วน collation หมายถึง กลุ่มของกฎเกณฑ์ที่ใช้ในการเปรียบเทียบอักขระต่างๆ ใน กลุ่มอักขระหนึ่งๆ สำหรับภาษาไทยมีกลุ่มอักขระคือ tis620 และมี collation คือ tis620_thai_ci

ทั้งนี้ระดับการใช้งานของ charcter set และ collation มีอยู่ด้วยกันทั้งหมด 4 ระดับคือ server database table และ connection สำหรับปัญหาที่ผมเจอนี้ ผมมุ่งประเด็นไปที่ connection โดยตั้งสมมติฐานว่าปัญหาของการแสดงผลภาษาไทยที่ผิดพลาดน่าจะเกิดระหว่างการติดต่อระหว่าง client (php script) กับ server (MySQL server)

สิ่งที่เกิดขึ้นระหว่างการติดต่อระหว่าง client และ server คือ client จะส่ง SQL statement เช่น query ต่างๆ ให้กับ server หลังจากนั้น server ก็จะตอบกลับ เช่น การส่งผลลัพธ์ของ SQL statement นั้นๆ กลับไปให้ client ในระหว่างที่มีการติดต่อกันนี้จะมีส่วนของ character set และ collation เข้ามาเกี่ยวข้อง คือ

  1. Character set ของ client ในขณะที่ส่ง query ให้กับ server: มีตัวแปรที่เกี่ยวข้องคือ character_set_client
  2. Character set ที่ server แปล query หลังจากที่ได้รับจาก client: ตัวแปรที่เกี่ยวข้องคือ character_set_connection และ collation_connection โดย server จะใช้ค่าของตัวแปร character_set_connection ในการแปล character set ของ query ที่ client ส่งมา ( character_set_client) ให้เป็นตามค่าที่กำหนดไว้ในตัวแปร character_set_connection
  3. Character set ที่ server จะทำการแปลก่อนที่จะส่งผลลัพธ์กลับไปให้แก่ client: ตัวแปรที่เกี่ยวข้องคือ character_set_results

ดังนั้นตัวแปรที่ควรจะทำการตรวจสอบก่อนก็คือ character_set_results ว่าค่าของตัวแปรนั้นเป็นค่าอะไรหรือเป็นค่าที่เกี่ยวข้องกับปัญหานี้หรือไม่  ผมทดสอบโดยการกำหนดค่าให้ chacter_set_results มีค่าเป็น tis620 ก่อนจะทำการส่ง query จริงๆ ไปให้แก่ MySQL  โดยการใช้คำสั่งต่อไปนี้

$charset = "SET character_set_results=tis620";
mysql_query($charset) or die('Invalid query: ' . mysql_error());

ผลปรากฎว่าการกำหนดค่าให้ตัวแปร character_set_results มีค่าเป็น tis620 ดังกล่าว สามารถช่วยแก้ปัญหาแสดงผลภาษาไทยที่ไม่ถูกต้องได้   นอกจากนี้สามารถใช้คำสั่งต่อไปนี้ในการแก้ปัญหาภาษาไทย คือ

  • SET NAMES 'tis620' ซึ่งมีค่าเทียบเท่ากับ
    • SET character_set_client='tis620'
    • SET character_set_results='tis620'
    • SET character_set_connection='tis620'
  • SET chracter_set_results=NULL  ซึ่งมีความหมายคือ ไม่ต้องการให้ server ทำการแปลงข้อมูลก่อนที่จะทำการส่งให้กับ client

สรุปแล้วปัญหาที่เกิดขึ้นน่าจะเกิดจากค่าของตัวแปร character_set_results ซึ่งถูกกำหนดให้เป็น character set ที่ไม่ใช่ tis620 ทำให้อักขระภาษาไทยที่ส่งกลับมาให้ client นั้นแสดงผลไม่ถูกต้อง  วิธีการแก้ปัญหาของผมในขณะนี้คือ ต้องแทรกคำสั่งที่กำหนดให้ character_set_results เป็น tis620 ก่อนที่จะทำการส่ง query จริงๆ ไปให้แก่ MySQL  ผมเองค่อนข้างงงว่าเหตุใดการกำหนดคำสั่ง default-character-set=tis620 ไม่สามารถแก้ปัญหานี้ได้  หากมีคำแนะนำหรือมีข้อเสนอแนะสามารถเขียนแจ้งมาได้นะครับที่ webmaster [a] phpconcept.com

ส่วนนี้เพิ่มเติมโดยอดิศร
จากประสบการณ์การใช้งานผมได้สร้าง PHP Script ที่ใช้สำหรับการติดต่อกับ MySQL ชุดหนึ่งซึ่งใน Script นี้จะมีการเซ็ตค่าภาษาไทยที่สามารถใช้งานได้ดีโดยไม่มีปัญหาภาษาไทย ทั้งการ Insert , Update, Select ดังนี้ครับ :
----------------------------------------------------------------------------------------------------------------------------------------------------
<?
//กำหนด ชื่อดาต้าเบสเซิร์ฟเวอร์ , ชื่อฐานข้อมูล , ล็อกอิน และ รหัสผ่าน สำหรับติดต่อกับฐานข้อมูลให้กับตัวแปร
$ServerName = "localhost";
$DatabaseName = "MyDatabase";
$User = "root";
$Password = "";

//ติดต่อกับฐานข้อมูลผ่านฟังก์ชัน MySQL
$Conn = mysql_connect($ServerName,$User,$Password) or die ("ไม่สามารถติดต่อกับเซิร์ฟเวอร์ได้");

//เลือกชื่อฐานข้อมูล คือ
mysql_select_db($DatabaseName,$Conn) or die ("ไม่สามารถติดต่อกับฐานข้อมูลได้");

$cs1 = "SET character_set_results=tis620";
mysql_query($cs1) or die('Error query: ' . mysql_error());

$cs2 = "SET character_set_client = tis620";
mysql_query($cs2) or die('Error query: ' . mysql_error());

$cs3 = "SET character_set_connection = tis620";
mysql_query($cs3) or die('Error query: ' . mysql_error());
?>
---------------------------------------------------------------------------------------------------------------------------------------------------

หวังว่าบทความนี้จะช่วยแก้ปัญหาให้กับบางท่านได้นะครับ :)

 

ที่มา : http://www.itwizard.info/technology/MySQL/MySQL_with_thai.html




ความคิดเห็นของคุณกับบทความนี้ ...

 

user_icon

Knowledge Center
knowledge center
knowledge

star

ผู้นำในภาวะวิกฤต
 
เรื่องน่ารู้ตามหมวดหมู่
• การแพทย์
• ความรู้ทั่วไป
• เรื่องของผู้หญิง
• กีฬา
• ข่าวและสื่อ

และอื่น ๆ อีกมาก

  ค้นหาเรื่องที่คุณสนใจ
ระบุ keyword
 
True vision

TV Icon

TV Interview

หลากเรื่องราวทางธุรกิจ แง่มุมของผู้บริหาร จากบริษัทชั้นนำต่างๆ

dot
HR Corner
สัมภาษณ์คัดเลือกผู้สมัครงานอย่างไร? ให้ตรงสเป็ค
https://www.jobpub.com/new_images/play.gif
 
The Seeds of Innovation นวัตกรรมใหม่แห่งการพัฒนาบุคลากร
https://www.jobpub.com/new_images/play.gif
 
การสร้างความแตกต่าง ให้เหนือคู่แข่ง
คุณมกร พฤฒิโฆสิต
https://www.jobpub.com/new_images/play.gif
dot

https://www.jobpub.com/new_images/playall_b.gif

 

หางานบ่อย : กาแฟ เชียงใหม่ งานบริการในเชียงรายวุฒิม.6 กุ๊ก ผช.กุ๊ก หางานครูผู้ช่วย บางแค พาสทาม ทุกธนาคาร ชลบุรี legal โรงเรียนวุฒิปวส. สมัครงานdtacยะลา ผู้จัดการ บัญชี กรุงเทพ พนักงานยขาย บัญชีการเงินชลบุรี เวชระเบียนลาดพร้าว งานราชการ เสริฟเขตรังสิต เจ้าหน้าที่ขาย บ้าน กม.28 พนักงานร้านแว่นตา จังหวัดแพร่ Brandname qq หางานวุฒิ ม.3กำแพงเพชร เขาแก้ว ครปฐม ธุรการ,ศรีราชา รพ.กรุงเทพ-พัทยา งาน CPF ช่างเทคนิค,ฝ่ายผลิต,QC วาด ภาพ สมัครงานวุฒิม.6 โคราช พนักงานขาย ถนนสุขุมวิท เจ้าหน้าที่ธุรการแถวบึงกุ่ม พนักงาน call center โปลิโฟม ce รฏยฟยฝรฏยฟยฝรฏยฟยฝ ฝ่ายผลิตต่างประเทศ ช่างไฟฟ้าไฟฟ้าสาย5 ปวส.ปตท. เกาะสมุยงาน ผู้จัดการ วิศวกรรม ลาดพร้าว ford mortor สนามบินสุวรรณภูมิ 2553 กรุงเทพ/ปริมณฑล hotel manager เชียงใหม่ พนักงาน QA-QC vj งานโรงเรียน แถวนวนคร บริษัทโภคชนาการ ช่าง ลำลูกกา ชลบุรี รูปภาพ