Mysql
 sql >> डेटाबेस >  >> RDS >> Mysql

Utf8 का उपयोग करने के लिए या नहीं - MySQL और PHP वर्ण एन्कोडिंग समस्या

आपकी समस्या यह है कि आपका SET NAMES 'utf8_persian_ci' . है आदेश अमान्य था (utf8_persion_ci एक संयोजन है , नहीं एक एन्कोडिंग ) यदि आप इसे टर्मिनल में चलाते हैं तो आपको एक त्रुटि दिखाई देगी Unknown character set: 'utf8_persian_ci' . इस प्रकार आपका आवेदन, जब यह संग्रहीत डेटा, latin1 . का उपयोग कर रहा था अक्षरों का समूह। MySQL ने आपके इनपुट को लैटिन 1 वर्णों के रूप में व्याख्यायित किया, जिसे बाद में इसे utf-8 के रूप में एन्कोड किया गया। इसी तरह जब डेटा को वापस बाहर निकाला गया, तो MySQL ने इसे UTF-8 से वापस latin1 में बदल दिया और (उम्मीद है, ज्यादातर समय) मूल बाइट्स जो आपने इसे दिया था।

दूसरे शब्दों में, डेटाबेस में आपका सारा डेटा पूरी तरह से गड़बड़ हो गया है, लेकिन यह काम करने के लिए ऐसा ही हुआ।

इसे ठीक करने के लिए, आपने जो किया उसे पूर्ववत करने की आवश्यकता है। PHP का उपयोग करने का सबसे सीधा तरीका है:

  1. SET NAMES latin1;
  2. हर टेबल से हर एक टेक्स्ट फील्ड को चुनें।
  3. SET NAMES utf8;
  4. एक ही स्ट्रिंग का उपयोग करके समान पंक्तियों को बिना किसी परिवर्तन के अपडेट करें।

वैकल्पिक रूप से आप इन चरणों को MySQL के अंदर कर सकते हैं, लेकिन यह मुश्किल है क्योंकि MySQL डेटा को एक निश्चित वर्ण सेट में समझता है। आपको अपने टेक्स्ट कॉलम को बीएलओबी प्रकार में संशोधित करना होगा, फिर उन्हें वापस संशोधित करना होगा utf8 कैरेक्टर सेट के साथ टेक्स्ट टाइप करने के लिए। ALTER TABLE लाल रंग में "चेतावनी" लेबल वाला MySQL दस्तावेज़

इन चीजों में से किसी एक को करने के बाद, आपके डेटाबेस कॉलम में संग्रहीत बाइट वास्तविक वर्ण सेट होंगे जो वे होने का दावा करते हैं। फिर, सुनिश्चित करें कि आप हमेशा mysql_set_charset('utf8') PHP से किसी भी डेटाबेस एक्सेस पर जो आप भविष्य में कर सकते हैं! नहीं तो आप फिर से चीजों को गड़बड़ कर देंगे। (ध्यान दें, एक साधारण mysql_query('SET NAMES utf8') का उपयोग न करें ! कोने के मामले हैं (जैसे एक रीसेट कनेक्शन) जहां इसे latin1 . पर रीसेट किया जा सकता है आपकी जानकारी के बिना। mysql_set_charset() जब भी आवश्यक होगा वर्णसेट सेट कर देगा।)

यह सबसे अच्छा होगा यदि आप mysql_* . से दूर चले गए हैं फ़ंक्शन और प्रयुक्त PDO इसके बजाय charset=utf8 . के साथ आपके PDO dsn में पैरामीटर ।



  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. नवीनतम परिणाम प्रदर्शित करने के लिए MySQL Group By

  2. MySQL MOD () फ़ंक्शन - MySQL में एक मोडुलो ऑपरेशन करें

  3. पायथन MySQLdb कनेक्शन के लिए SSH टनल

  4. रेक निरस्त! अप्रारंभीकृत स्थिर Mysql2

  5. पहले अक्षर से समूह, वर्णानुक्रम में, सबसे अच्छा तरीका?