我试图运行以下PHP脚本做一个简单的数据库查询:

$db_host = "localhost";
$db_name = "showfinder";
$username = "user";
$password = "password";
$dbconn = pg_connect("host=$db_host dbname=$db_name user=$username password=$password")
    or die('Could not connect: ' . pg_last_error());

$query = 'SELECT * FROM sf_bands LIMIT 10';
$result = pg_query($query) or die('Query failed: ' . pg_last_error());

这会产生以下错误:

查询失败:ERROR:关系“sf_bands”不存在

在我能找到的所有例子中,有人得到一个错误,说明关系不存在,这是因为他们在表名中使用大写字母。我的表名没有大写字母。是否有一种方法来查询我的表不包括数据库名称,即showfinder.sf_bands?


当前回答

这对一些人来说可能是愚蠢的,但在我的情况下-一旦我创建了表,我就可以在同一会话上查询表,但如果我重新登录新的会话表不退出。

然后我在创建表后使用commit,现在我可以在新会话中查找和查询表。是这样的:

select * from my_schema.my_tbl;

希望这能帮助到一些人。

其他回答

除了Bill Karwin的答案=>

是的,您应该用双引号括起表名。但是,请注意,php很可能不允许你简单地写:

$query = "SELECT * FROM "SF_Bands"";

相反,您应该像sav所说的那样在包围查询时使用单引号。

$query = 'SELECT * FROM "SF_Bands"';

从我所读到的,这个错误意味着您没有正确引用表名。一个常见的原因是,表定义为混合大小写拼写,并且您试图用所有小写字母查询它。

换句话说,以下是不成立的:

CREATE TABLE "SF_Bands" ( ... );

SELECT * FROM sf_bands;  -- ERROR!

使用双引号分隔标识符,以便在定义表时使用特定的混合大小写拼写。

SELECT * FROM "SF_Bands";

关于你的注释,你可以在“search_path”中添加一个模式,这样当你引用一个表名而不限定它的模式时,查询将通过按顺序检查每个模式来匹配该表名。就像shell中的PATH或PHP中的include_path,等等。您可以查看当前的模式搜索路径:

SHOW search_path
  "$user",public

您可以更改模式搜索路径:

SET search_path TO showfinder,public;

参见http://www.postgresql.org/docs/8.3/static/ddl-schemas.html

这对一些人来说可能是愚蠢的,但在我的情况下-一旦我创建了表,我就可以在同一会话上查询表,但如果我重新登录新的会话表不退出。

然后我在创建表后使用commit,现在我可以在新会话中查找和查询表。是这样的:

select * from my_schema.my_tbl;

希望这能帮助到一些人。

对我来说,问题是,当Django初始化时,我对那个特定的表使用了查询。当然,它会抛出一个错误,因为这些表并不存在。在我的例子中,它是admin.py文件中的get_or_create方法,当软件运行任何类型的操作(在本例中是迁移)时执行该方法。希望这能帮助到别人。

我建议检查是否运行了迁移,或者数据库中是否存在该表。