9

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

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

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

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

4

4 回答 4

21

步骤: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
}
?>
于 2012-07-01T08:42:45.130 回答
1

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

于 2012-11-11T09:06:34.927 回答
1

我遇到了同样的问题,并通过操纵整个 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 Query 从 MySQL 数据库中检索直接显示乌尔都语或任何其他语言。

于 2020-01-03T18:04:46.960 回答
0

我遇到了这个问题,我通过将它们转换为 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;
于 2019-04-21T12:09:03.360 回答