我的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 ? ? ?"
我希望有人可以帮助我:)
编辑:
htmlentities()完成了这项工作!
解决方法:
使用HTML实体并不是解决问题的最佳解决方案.理想情况下,您应该将数据存储在数据库中,并且仅使用htmlentities()进行显示.如果您希望以除HTML之外的其他方式显示/导出此数据,该怎么办?
我建议阅读PHP / MysqL中的字符集处理.这是我最近写的一篇文章:How to Avoid Character Encoding Problems in PHP
如果你还有问题,请再次发帖.