什么SQL可以用来列出表,以及在SQLite数据库文件中的这些表中的行-一旦我已经附加了它与SQLite 3命令行工具上的ATTACH命令?
当前回答
使用.da查看所有数据库-其中一个被称为“main”。
该数据库的表可以通过以下方式查看:
SELECT distinct tbl_name from sqlite_master order by 1;
附加的数据库需要在ATTACH语句中用AS选择前缀,例如aa (, bb, cc…),因此:
SELECT distinct tbl_name from **aa.sqlite_master** order by 1;
请注意,在这里您也可以获得视图。要排除这些,请添加:
where type = 'table'
在order之前
其他回答
看起来你需要遍历sqlite_master表,就像这样:
SELECT * FROM dbname.sqlite_master WHERE type='table';
然后用SELECT或类似的方法手动遍历每个表以查看行。
. dump和. schema命令似乎根本看不到数据库。
.tables和.schema“助手”函数不查找ATTACHed数据库:它们只查询SQLITE_MASTER表以查找“主”数据库。因此,如果你使用
ATTACH some_file.db AS my_db;
然后你需要做
SELECT name FROM my_db.sqlite_master WHERE type='table';
注意,临时表也不会用.tables显示:你必须列出sqlite_temp_master:
SELECT name FROM sqlite_temp_master WHERE type='table';
最简单的方法是直接打开数据库并使用.dump命令,而不是在调用SQLite 3 shell工具后附加它。
所以…(假设你的操作系统命令行提示符是$)而不是$sqlite3:
sqlite3> ATTACH database.sqlite as "attached"
从你的操作系统命令行,直接打开数据库:
$sqlite3 database.sqlite
sqlite3> .dump
在SQLite数据库中查看表有几个步骤:
列出数据库中的表: .tables 列出表格的外观: . schema的表 打印整个表格: SELECT * FROM tablename; 列出所有可用的SQLite提示命令: .help
要列出表格,您还可以这样做:
SELECT name FROM sqlite_master
WHERE type='table';