什么SQL可以用来列出表,以及在SQLite数据库文件中的这些表中的行-一旦我已经附加了它与SQLite 3命令行工具上的ATTACH命令?
当前回答
要列出表格,您还可以这样做:
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文件读取的文件都在同一个路径中。
使用.help检查可用的命令。
.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);
要列出表格,您还可以这样做:
SELECT name FROM sqlite_master
WHERE type='table';
在SQLite命令行中有一个命令可用:
.tables ?PATTERN? List names of tables matching a LIKE pattern
它转换为以下SQL:
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
推荐文章
- 如何从一个查询插入多行使用雄辩/流利
- 如何连接列在Postgres选择?
- 有人可以对SQL查询进行版权保护吗?
- 数据库触发器是必要的吗?
- 如何知道MySQL表最近一次更新?
- 如何转储一些SQLite3表的数据?
- 如何创建一个SQL Server函数“连接”多行从一个子查询到一个单独的分隔字段?
- 在MySQL中的一个查询中更新多个具有不同值的行
- 在SQL中更新多个列
- 如何删除表中特定列的第一个字符?
- MySQL OR与IN性能
- 为什么我应该使用基于文档的数据库而不是关系数据库?
- 哪个更快/最好?SELECT *或SELECT columnn1, colum2, column3等
- 将值从同一表中的一列复制到另一列
- 什么是数据库池?