1. 创建数据库
sqlite3 DatabaseName.db
注意:
- 数据库名称在 RDBMS 中应该是唯一的。
- sqlite3 命令: sqlite3 命令用于创建数据库。但是,如果数据库不存在,则会自动创建具有给定名称的新数据库文件。
- 用 sqlite3 创建数据库不会立即显示,需要在创建表后才会创建文件,可以用 . open 直接创建数据库文件
sqlite3 TNT.db
创建完成后可以在根文件夹中查看数据库,也可以在cmd窗口中通过.database和.databases命令查看创建的数据库。
.quit 命令用于退出 sqlite 提示符;
.dump dot 命令用于在命令提示符下使用 SQlite 命令将完整的数据库导出为文本文件。
2. 附加数据库
假设有多个可用的数据库,并且一次只能使用其中一个。这就是使用 ATTACH DATABASE 语句的原因。它方便选择特定的数据库,使用此命令后,所有 SQLite 语句都将在附加的数据库下执行。
ATTACH DATABASE 'DatabaseName'as'Alias-Name' ;
注意:如果数据库不存在,上面的语法也会创建一个数据库,否则它只会附加一个带有逻辑数据库别名的数据库文件名。
3. 分离数据库
SQLite DETACH DATABASE 语句用于从之前使用 ATTACH 语句附加的数据库连接中分离别名数据库。
如果同一个数据库文件附加了多个别名,则 DETACH 命令将仅断开给定的名称,其余的附件仍将继续。无法分离主数据库和临时数据库。
注意:内存或临时数据库中的数据库将被完全破坏,内容将丢失。
DETACH DATABASE 'Alias-Name'
4. 创建表
在 SQLite 中,CREATE TABLE 语句用于创建新表。创建表时,我们命名该表并定义其列和每列的数据类型。
CREATE TABLE database_name.table_name(
column1 datatype PRIMARY KEY(one or more columns),
column2 datatype,
column3 datatype,
.....
columnN datatype,
);
CREATE TABLE STUDENT(
ID INT PRIMARY KEY NOT NULL,
NAME TEXT NOT NULL,
AGE INT NOT NULL,
ADDRESS CHAR(50),
FEES REAL
);
查看表中信息:
PRAGMA table_info(students);
请注意,PRAGMA命令是SQLite特有的,并不属于SQL标准的一部分。因此,如果你在其他数据库系统中使用这些命令,可能会遇到问题。
5. 删除表
在 SQLite 中,DROP TABLE 语句用于删除表定义以及与该表关联的所有关联数据、索引、触发器、约束和权限规范。
DROP TABLE database_name.table_name;
注意:使用 DROP TABLE 命令时必须非常小心,因为一旦表被删除,所有可用信息都将被破坏,您将无法恢复。