5

希望是一个简单的问题。

    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

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

有任何想法吗???谢谢 :)。

4

3 回答 3

10

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

  1. 您没有连接到您认为的数据库(可能不是这种情况)
  2. 您没有使用该表的权限(请参阅 Justin Cave 关于格兰特的回答)
  3. 您可能需要将所有者添加到表名中,例如select * from DB_USER.mantis_bug_table(如果您不想限定表名,请参阅 Justin Cave 关于同义词的回答)
  4. 该表确实不存在,可能是拼写错误

您可以通过运行以下命令来诊断此问题

SELECT * FROM ALL_TABLES WHERE UPPER(table_name) = 'MANTIS_BUG_TABLE'
于 2011-08-26T15:08:35.703 回答
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)引用没有完全限定表名的表。

于 2011-08-26T15:12:11.753 回答
-1

您应该在连接字符串中指向方案,例如:

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

在connection_string部分查看http://www.php.net/manual/en/function.oci-connect.php

于 2011-08-26T15:09:23.907 回答