PHP - 显示从 MySQL 数据库检索的乌尔都语文本


PHP - Displaying Urdu text retrieved from MySQL DB

MySQL数据库中存储了乌尔都语的书名。我必须使用PHP在html页面上显示。

目前只显示问号(??????)代替乌尔都语文本。

<div class='product_title'><a href='details.php?pid=".$Row['s_id']."'>".$Row["books"]."</a></div>

需要做什么才能正确显示这些字符?

步骤 : 1 - 转到表结构并将排序规则latin1_swedish_ci更改为utf8_general_ci

步骤 : 2 -您必须在数据结果页中包含以下标记。

<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />

步骤 :3 - 插入"N"前缀。这里的 N 代表国家语言字符集。这意味着您正在传递NCHAR,NVARCHAR或NTEXT值,更多

步骤:4 - 显示数据库记录的PHP代码。在此之前,您必须指定 mysql_query() 函数数据字符集类型

<?php
include('db.php');
mysql_query ("set character_set_results='utf8'"); 
$query = mysql_query("SELECT * FROM books") or die(mysql_error());
while($row=mysql_fetch_array($query))
{
echo $row['id']; // Book id 
echo $row['books_title']; // Book title
}
?>

此外,您的文件编码必须是 utf-8,没有 BOM

我遇到了同样的问题,并通过操作整个PHP-MySQL环境的字符编码来解决。

默认情况下,PHPMyAdmin 中的字符集编码一般为拉丁瑞典语或 utf8 通用,但是,字符集编码不支持乌尔都语、中文等其他语言,因此您需要根据需要更改 MySQL 数据库或表或列的字符编码。

# For each database:
ALTER DATABASE database_name CHARACTER SET = utf8mb4 COLLATE = utf8mb4_general_ci;
# For each table:
ALTER TABLE table_name CONVERT TO CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci;
# For each column:
ALTER TABLE table_name CHANGE column_name column_name VARCHAR(191) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci;
# (Don’t blindly copy-paste this! The exact statement depends on the column type, maximum length, and other properties. The above line is just an example for a `VARCHAR` column.)

您还需要为使用 mysqli_query 检索的数据设置字符编码。您可以使用连接线正下方的 mysqli_charset() 函数来执行此操作。喜欢。。。

 // Create connection
$conn = mysqli_connect($servername, $username, $password, $dbname);
/* change character set to utf8mb4 */
mysqli_set_charset($conn,"utf8mb4");

现在,您可以通过PHP查询从MySQL数据库检索来直接显示乌尔都语或任何其他语言。

我遇到了这个问题,我已经通过将它们转换为 UTF-8 解决了这个错误。

ALTER TABLE test_Table_name CONVERT TO CHARACTER SET utf8 COLLATE utf8_general_ci;
ALTER TABLE test_Table_name DEFAULT CHARACTER SET utf8 COLLATE utf8_general_ci;
ALTER TABLE test_Table_name CHANGE title title VARCHAR(100) CHARACTER SET utf8 COLLATE utf8_general_ci;