是否有一种方式让非管理员PostgreSQL用户发现它可以在连接到的服务器上访问哪些数据库,更具体地说,这些数据库中的哪个有一个具有特定名称的表,用户有足够的权限查看(可能还有查询)?据我所知,MySQL等价物是这样的:
SELECT t.TABLE_SCHEMA FROM information_schema.
在上一集()中,我学习了如何在MySQL中构造跨数据库查询。这很有效,但是当我们的英雄试图使用PHP中新发现的知识时,他发现他最好的朋友在等他时失败了。我看了一下mysql_select_db for PHP。这似乎意味着,如果我想在PHP中使用MySQL,我有几个选择:
使用mysql_select_db,但一次只能使用一个db。这是我们当前的设置,将数据库作为命名空间标识符似乎不起作用(它在MySQL shell中工作得很好,
我正在开发一个如果安装了MySQL就会安装的WPF应用程序,因此在安装之前,我想检查mysql.proc表是否存在。最后得到了一个问题 where Table_schema = Schema() and Table_Name = 'mysql.proc'
此查询返回一个空行。我还尝试了简单的select语句select * from mysql.proc,这将返回一个包含所有存储过程名称的表,但是如