ホームページ >データベース >mysql チュートリアル >PHP と MySQL を使用してヒンディー語テキストを適切に保存および表示するにはどうすればよいですか?

PHP と MySQL を使用してヒンディー語テキストを適切に保存および表示するにはどうすればよいですか?

Mary-Kate Olsen
Mary-Kate Olsenオリジナル
2024-11-28 18:17:14181ブラウズ

How to Properly Store and Display Hindi Text Using PHP and MySQL?

PHP と MySQL を使用した Unicode 文字列の保存と表示 (हिन्दी)

問題:
ユーザーはヒンディー語の保存と表示に問題に直面していますPHP を使用して MySQL データベース内のテキストを作成します。テキストは「??????」と表示されます。 utf8_encode() を使用して取得およびエコーされたとき。

解決策:
問題を解決するには、次の手順を実行する必要があります:

  1. データベース エンコーディングの設定: データベース エンコーディングと照合順序の両方が UTF-8 に設定されていることを確認します。これは、データベース操作の前にクエリ「SET NAMES utf8」を実行することによって行われます。
  2. データベースの文字セットを指定: ヒンディー語テキストを保存するテーブルとフィールドを作成するときに、 UTF-8 として文字セット。
  3. ページ エンコーディングを設定: HTML ヘッダー セクションPHP ページで、メタ タグを追加してページ エンコーディングを UTF-8 に設定します:
<meta http-equiv="Content-Type" content="text/html;charset=UTF-8">
  1. コンテンツ タイプ ヘッダーを設定: または、コンテンツを設定することもできますPHP スクリプトを入力します使用:
header('Content-Type: text/html; charset=utf-8');
  1. PHP スクリプトの例: 次の PHP スクリプトはプロセスを示します:
<?php
include("connection.php"); // Include database connection
mysql_query("SET NAMES utf8"); // Set database character set
$result = mysql_query("select * from hindi"); // Fetch data from the database
while ($myrow = mysql_fetch_row($result)) {
    echo ($myrow[0]); // Echo the Hindi text
}
?>
  1. データベース テーブル: データベース テーブルの構造は次のようになります。これ:
CREATE TABLE `hindi` (
  `data` varchar(1000) character set utf8 collate utf8_bin default NULL
) ENGINE=InnoDB DEFAULT CHARSET=latin1;

追加メモ:

  • ユーザーは、ヒンディー語テキストを HTML エンティティに変換する可能性のあるスクリプトについても質問しました。ただし、提供されたソリューションにはそのようなスクリプトはありません。
  • ユーザーは、「META」またはヘッダー情報を指定せずに PHP スクリプトがどのように動作するかについて問い合わせました。ただし、提供される解決策には、PHP スクリプトと HTML ヘッド セクションの両方で文字セットを設定することが含まれます。これは、ヒンディー語テキストを正しく表示するために不可欠です。

以上がPHP と MySQL を使用してヒンディー語テキストを適切に保存および表示するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。