来自oracle的数据来自utf-8与php

时间:2013-11-15 07:51:34

标签: php oracle

我有一个从oracle数据库获取数据的问题。如何在utf-8中获取数据?浏览器显示带有echo的符号,但来自oracle的数据有哪些?标记而不是字母

    <head>
<meta http-equiv="content-type" content="text/html; charset=utf-8"></meta>
</head>
<?php

 $tns2 = "(DESCRIPTION = (ADDRESS = (PROTOCOL = TCP)(HOST = hostname)(PORT = 1521)) (CONNECT_DATA = (SID = sidname)))";
   if ($conn = oci_connect("user","pass", $tns2))
   {
       echo "YAY!";
       //oci_close($conn);
   }
   else
   {
       die("Nesiseka");
   }

$stid = oci_parse($conn, 'SELECT * rowname where rownum<=10');
oci_execute($stid);

oci_close($conn);

echo "<table border='1'>\n";
while ($row = oci_fetch_array($stid, OCI_ASSOC+OCI_RETURN_NULLS)) {
    echo "<tr>\n";
    foreach ($row as $item) {
        echo "    <td>" . ($item !== null ? htmlentities($item, ENT_QUOTES) : "&nbsp;") . "</td>\n";
    }
    echo "</tr>\n";
}
echo "</table>\n";
echo"įęėšųį";
?>

3 个答案:

答案 0 :(得分:30)

简单的解决方案。只将'AL32UTF8'添加到行if ($conn = oci_connect(username,pass, $tns2 , 'AL32UTF8'))现在一切正常。 谢谢你的帮助

答案 1 :(得分:3)

使用它来建立数据库连接:

$conn = oci_connect(username,pass, $tns2 , 'AL32UTF8')

答案 2 :(得分:0)

将php编码设置为utf 8

mb_internal_encoding("UTF-8");

链接了解更多信息  http://php.net/manual/en/function.mb-internal-encoding.php