MySQL 数据库中存储有乌尔都语的书名。我必须使用 PHP 在 html 页面上显示。
目前仅显示问号 ( ??????
) 来代替乌尔都语文本。
<div class='product_title'><a href='details.php?pid=".$Row['s_id']."'>".$Row["books"]."</a></div>
需要做什么才能正确显示这些字符?
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
}
?>
此外,您的文件编码必须是没有 BOM 的 utf-8
我遇到了同样的问题,并通过操纵整个 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 数据库中检索直接显示乌尔都语或任何其他语言。
我遇到了这个问题,我通过将它们转换为 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;