How to list the tables in a SQLite database file that was opened with ATTACH?

前端 未结 17 2273
被撕碎了的回忆
被撕碎了的回忆 2020-11-22 11:33

What SQL can be used to list the tables, and the rows within those tables in an SQLite database file - once I have attached it with the

相关标签:
17条回答
  • 2020-11-22 12:09

    To show all tables, use

    SELECT name FROM sqlite_master WHERE type = "table"
    

    To show all rows, I guess you can iterate through all tables and just do a SELECT * on each one. But maybe a DUMP is what you're after?

    0 讨论(0)
  • 2020-11-22 12:10

    I use this query to get it:

    SELECT name FROM sqlite_master WHERE type='table'
    

    And to use in iOS:

    NSString *aStrQuery=[NSString stringWithFormat:@"SELECT name FROM sqlite_master WHERE type='table'"];
    
    0 讨论(0)
  • 2020-11-22 12:12

    According to the documentation, the equivalent of MySQLs' SHOW TABLES; is:

    The ".tables" command is similar to setting list mode then executing the following query:

    SELECT name FROM sqlite_master
      WHERE type IN ('table','view') AND name NOT LIKE 'sqlite_%'
    UNION ALL
    SELECT name FROM sqlite_temp_master
      WHERE type IN ('table','view')
    ORDER BY 1;
    

    However, if you are checking if a single table exists (or to get its details), see @LuizGeron answer.

    0 讨论(0)
  • 2020-11-22 12:14

    The easiest way to do this is to open the database directly and use the .dump command, rather than attaching it after invoking the SQLite 3 shell tool.

    So... (assume your OS command line prompt is $) instead of $sqlite3:

    sqlite3> ATTACH database.sqlite as "attached"
    

    From your OS command line, open the database directly:

    $sqlite3 database.sqlite
    sqlite3> .dump
    
    0 讨论(0)
  • 2020-11-22 12:17

    Try PRAGMA table_info(table-name);
    http://www.sqlite.org/pragma.html#schema

    0 讨论(0)
  • 2020-11-22 12:17

    Since nobody has mentioned about the official reference of SQLite, I think it may be useful to refer to it under this heading:

    https://www.sqlite.org/cli.html

    You can manipulate your database using the commands described in this link. Besides, if you are using Windows OS and do not know where the command shell is, that is in the SQLite's site:

    https://www.sqlite.org/download.html

    After downloading it, click sqlite3.exe file to initialize the SQLite command shell. When it is initialized, by default this SQLite session is using an in-memory database, not a file on disk, and so all changes will be lost when the session exits. To use a persistent disk file as the database, enter the ".open ex1.db" command immediately after the terminal window starts up.

    The example above causes the database file named "ex1.db" to be opened and used, and created if it does not previously exist. You might want to use a full pathname to ensure that the file is in the directory that you think it is in. Use forward-slashes as the directory separator character. In other words use "c:/work/ex1.db", not "c:\work\ex1.db".

    To see all tables in the database you have previously chosen, type the command .tables as it is said in the above link.

    If you work in Windows, I think it might be useful to move this sqlite.exe file to same folder with the other Python files. In this way, the Python file writes to and the SQLite shell reads from .db files are in the same path.

    0 讨论(0)
提交回复
热议问题