什么SQL可以用来列出表,以及在SQLite数据库文件中的这些表中的行-一旦我已经附加了它与SQLite 3命令行工具上的ATTACH命令?
当前回答
Use:
import sqlite3
TABLE_LIST_QUERY = "SELECT * FROM sqlite_master where type='table'"
其他回答
”。Schema " commando将列出可用的表及其行,通过显示用于创建上述表的语句:
sqlite> create table_a (id int, a int, b int); sqlite> .schema table_a CREATE TABLE table_a (id int, a int, b int);
最简单的方法是直接打开数据库并使用.dump命令,而不是在调用SQLite 3 shell工具后附加它。
所以…(假设你的操作系统命令行提示符是$)而不是$sqlite3:
sqlite3> ATTACH database.sqlite as "attached"
从你的操作系统命令行,直接打开数据库:
$sqlite3 database.sqlite
sqlite3> .dump
根据文档,相当于MySQL的SHOW TABLES;是:
”。“Tables”命令类似于设置列表模式然后执行 查询:
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;
但是,如果您正在检查单个表是否存在(或获取其详细信息),请参阅LuizGeron的答案。
Use:
import sqlite3
TABLE_LIST_QUERY = "SELECT * FROM sqlite_master where type='table'"
使用.help检查可用的命令。
.table
这个命令将显示当前数据库下的所有表。