Oracle SELECT语句不起作用 - ORA-00942

时间:2011-08-26 15:03:16

标签: php oracle ora-00942

希望这是一个简单的问题。

    error_reporting(E_ALL);
    ini_set('display_errors', '1');
    $c = oci_connect('whatmyusrnameis', 'whatmypwdis', 'host');
    if ($c) {
            echo 'connection';

    }
    $s = oci_parse($c, 'select *  from mantis_bug_table');
    oci_execute($s);

以下结果

警告oci_execute(): ORA-00942: table or view does not exist

但连接不会导致任何错误,并且DB表确实存在且不为空。

任何想法???谢谢你:)。

3 个答案:

答案 0 :(得分:9)

通常这有四个可能的问题之一

  1. 您没有连接到您认为自己的数据库(可能不是这种情况)
  2. 你没有表格的许可(参见Justin Cave关于格兰特的回答)
  3. 您可能需要将所有者添加到表名称,例如select * from DB_USER.mantis_bug_table(如果您不想要限定表名,请参阅Justin Cave关于SYNONYM的答案)
  4. 该表确实不存在拼写错误
  5. 您可以通过运行以下

    来诊断此问题
    SELECT * FROM ALL_TABLES WHERE UPPER(table_name) = 'MANTIS_BUG_TABLE'
    

答案 1 :(得分:3)

  • Oracle用户拥有哪些表?
  • 您的PHP脚本连接的Oracle用户是否可以访问此表?
  • 是否有MANTIS_BUG_TABLE表的公共或私人同义词?

如果该表归其他用户所有,您可以尝试完全限定表名

$s = oci_parse($c, 'select *  from owner_of_table.mantis_bug_table');

如果您的PHP脚本使用的用户无权访问该表,则您需要DBA或该表的所有者

GRANT SELECT ON owner_of_table.mantis_bug_table
   TO whatmyusernameis;

如果您有权访问该表并完全限定表名,但您不希望每次都完全限定表名,则可以创建同义词

CREATE [PUBLIC] SYNONYM mantis_bug_table
   FOR owner_of_table.mantis_bug_table

公共同义词允许所有有权访问该表的用户在不使用完全限定名的情况下引用该表。私有同义词只允许同义词的所有者(即whatmyusernameis)引用该表而没有完全限定的表名。

答案 2 :(得分:-1)

您应该将方案指向连接字符串,如:

oci_connect('whatmyusrnameis', 'whatmypwdis', 'host/**YOUR_DB**');

查看 connection_string

部分中的http://www.php.net/manual/en/function.oci-connect.php