MYSQL INSERT中的德语变音符号

Don*_*oce 5 php mysql

我的mysql插入语句有问题.我有一个表单,正确地向插入文件提交utf-8字符(我检查了POST变量).

现在,当我在我的数据库中查看INSERT时,没有变音符号,而是问号.

错误必须在insert语句之前.

如果我从我的数据库输出(手动输入)内容,则会正确显示变音符号.

// echo $_POST["title"];
// outputs correctly with special chars: "Some german title with umlaute ä ö ü"

mysql_query("INSERT INTO videos (youtube_hash, title, description, category, created) VALUES ('".mysql_real_escape_string($_POST["hash"])."', '".mysql_real_escape_string($_POST["title"])."', '".mysql_real_escape_string($_POST["desc"])."', '".mysql_real_escape_string($_POST["cat"])."', '".time()."')") or die(mysql_error());

// database entry looks like this: "Some german title with umlaute ? ? ?"
Run Code Online (Sandbox Code Playgroud)

我希望有人可以帮助我:)

编辑:

htmlentities()完成了这项工作!

Jam*_*s C 1

使用 HTML 实体并不是解决问题的最佳方案。理想情况下,您应该将数据存储在数据库中并且仅用于htmlentities()显示目的。如果您想以 HTML 以外的其他方式显示/导出此数据,该怎么办?

我建议阅读 PHP/MySQL 中的字符集处理。这是我最近写的一篇文章:如何避免 PHP 中的字符编码问题

如果您仍然遇到问题,请再次发布。