什么SQL可以用来列出表,以及在SQLite数据库文件中的这些表中的行-一旦我已经附加了它与SQLite 3命令行工具上的ATTACH命令?
当前回答
要显示所有表,使用
SELECT name FROM sqlite_master WHERE type = "table"
要显示所有行,我认为可以遍历所有表,并在每个表上执行SELECT *。但也许垃圾场才是你想要的?
其他回答
看起来你需要遍历sqlite_master表,就像这样:
SELECT * FROM dbname.sqlite_master WHERE type='table';
然后用SELECT或类似的方法手动遍历每个表以查看行。
. dump和. schema命令似乎根本看不到数据库。
要显示所有表,使用
SELECT name FROM sqlite_master WHERE type = "table"
要显示所有行,我认为可以遍历所有表,并在每个表上执行SELECT *。但也许垃圾场才是你想要的?
使用.help检查可用的命令。
.table
这个命令将显示当前数据库下的所有表。
我使用这个查询来获得它:
SELECT name FROM sqlite_master WHERE type='table'
在iOS中使用:
NSString *aStrQuery=[NSString stringWithFormat:@"SELECT name FROM sqlite_master WHERE type='table'"];
由于没有人提到SQLite的官方引用,我认为在以下标题下引用它可能是有用的:
https://www.sqlite.org/cli.html
可以使用此链接中描述的命令操作数据库。此外,如果你使用的是Windows操作系统,不知道命令shell在哪里,那就是在SQLite的网站上:
https://www.sqlite.org/download.html
下载后,单击sqlite3.exe文件来初始化SQLite命令shell。初始化时,默认情况下,这个SQLite会话使用内存中的数据库,而不是磁盘上的文件,因此当会话退出时,所有更改都将丢失。若要使用持久磁盘文件作为数据库,请输入“。终端窗口启动后立即打开ex1.db”命令。
上面的示例导致打开和使用名为“ex1.db”的数据库文件,如果以前不存在,则创建该文件。您可能希望使用完整的路径名来确保文件位于您认为它所在的目录中。使用正斜杠作为目录分隔符。换句话说,使用“c:/work/ex1.db”,而不是“c:\work\ex1.db”。
要查看您之前选择的数据库中的所有表,请键入上面链接中所说的.tables命令。
如果你在Windows下工作,我认为将这个sqlite.exe文件移动到与其他Python文件相同的文件夹中可能会很有用。这样,Python文件写入的文件和SQLite shell从.db文件读取的文件都在同一个路径中。
推荐文章
- 选项(RECOMPILE)总是更快;为什么?
- 设置数据库从单用户模式到多用户
- oracle中的RANK()和DENSE_RANK()函数有什么区别?
- 的类型不能用作索引中的键列
- SQL逻辑运算符优先级:And和Or
- 如何检查一个表是否存在于给定的模式中
- 添加一个复合主键
- 如何在SQL Server Management Studio中查看查询历史
- 可以为公共表表达式创建嵌套WITH子句吗?
- 什么时候我需要在Oracle SQL中使用分号vs斜杠?
- SQL Server的NOW()?
- 在SQL中,count(列)和count(*)之间的区别是什么?
- 在SQL Server中截断(不是四舍五入)小数位
- 仅在Datetime列上按日期分组
- PostgreSQL通配符LIKE用于单词列表中的任何一个