On 15/05/12 12:06 PM, Vernon Cole wrote:
Eddy:
   As you discovered, every different database system has a unique way
of getting a table listing.  The problem with attempting to make a
uniform tool for doing that at the PEP 249 level, is that some api
packages (such as the one I maintain for Microsoft ADO, and anything
that does ODBC) may attach to dozens of different engines.  Mine will
basically hook up to anything _except_ sqlite. I have no idea which
engine or engines may show up at the other end.  I attempt to let the
user determine that by prividing the  non-standard attributes
connection.dbs_name and connection.dbs_version.  (I borrowed the idea
from mxodbc.)  The most we should hope for at the PEP 249 level would be
to have those attributes become part of the standard.

   I think that it would be wonderful if someone (you could volunteer)
were to make a package which does exactly what you suggest. That package
would have to determine what the underlying engine is, then give the
correct commands. If you write it, I will use it.  I'ld even contribute
the query for Microsft SQL tables.
--
Vernon Cole

On Mon, May 14, 2012 at 8:33 AM, Edward Welbourne <e...@chaos.org.uk
<mailto:e...@chaos.org.uk>> wrote:

    Hi DB-sig,

    I'm digging data out of my mobile 'phone so that I don't lose it during
    an upgrade.  It turns out to hold my address-book in a sqlite database,
    so I duly connected to that using the pysqlite2 package; which
    implements PEP 249 (DB API 2.0) - indeed, the nearest it gets to
    documentation was something google found me that mentioned it
    implemented the PEP.  (Hint to the maintainer if reading this: the
    .__doc__ of either pysqlite2 or its .dbapi2 would be a good place to say
    that, ideally complete with the PEP's URL.)

    I looked at SQL references and at the PEP but nothing tells me a
    standardised way to ask a database its list of tables.  SQL tutorials
    seem to assume I created the tables, so obviously know their names; the
    explorer trying to make sense of a found database isn't considered.  It
    would seem that each database has its own idiosyncratic way of getting
    such a list, typically be selecting from a special table, whose name
    varies from database to database, as does the column name for the names
    of tables.

    Oracle:
    SELECT table_name FROM user_tables
    (or SELECT owner, table_name FROM all_tables, or FROM dba_tables).

    SQLite:
    SELECT name FROM sqlite_master WHERE type='table';
    Notice the need for a WHERE clause, in this case.

    MS's SQL server uses meta-table sys.tables, if my googling is accurate,
    but the source didn't say what column-name to ask for.

    Most of SQL is sufficiently standardised to permit writing portable code
    to explore a database - provided access compatible with PEP 249 is
    available - without need to know details of the SQL implementation; so
    it would be nice if some future version of the DB API were to specify a
    standard method, of connection objects, that can be used to obtain the
    list of tables available via the connection.

    I can imagine that most of the other information in meta-tables and
    kindred magic is only actually useful in conjunction with other
    implementation-specific features of the database, so not worth exposing
    in a portable form; but having a list of the table-names I can use in
    plain SQL queries is useful in general, without need for reference to
    (other) implementation details.

    A sufficient solution - for the three sample databases for which I found
    details - would be to provide a string global of the module,
    implementing the DB API, whose value is an SQL string that can be passed
    as the command to its .connect(whatever).cursor().execute(command); but
    I suspect it would make better sense to provide a separate method of
    connection objects, that simply returns a list of (or iterator over)
    table names.

            Eddy.
    --
    Note: I'm not on DB-sig, so please keep me overtly CC'd in replies, if
    you care whether I see them !

This is hard. Gerald [1] attempts to provide a compact but meaningful and consistent data dictionary for a number of backends (currently Oracle, MySQL and Postgres). Patches or suggestions for improvement - including a module for SQLite - are welcome.

The industry standard (if such a term can be used) is for relational databases to provide an INFORMATION_SCHEMA [2]. The problem with this is that where it is provided (and AFAIK SQLite doesn't) not all databases are equal (MySQL doesn't provide 'referential_constraints' for instance) and some key pieces of information aren't included. Although to be fair these are usually elements such as tablespace which are implementation specific so wouldn't be expected to be available in 'standard' views.

[1] http://halfcooked.com/code/gerald/
[2] https://en.wikipedia.org/wiki/Information_Schema

Regards,
Andy
--
From the desk of Andrew J Todd esq - http://www.halfcooked.com/
_______________________________________________
DB-SIG maillist  -  DB-SIG@python.org
http://mail.python.org/mailman/listinfo/db-sig

Reply via email to