SQLite VIEW关键字用于创建SQLite VIEW,它是基于SQLite语句创建的虚拟表。视图包含行和列,就像普通表一样。所有 SQLite 函数,WHERE、HAVING 和 JOIN 语句可用于创建 SQLite VIEW。 SQLite VIEW 语句可用于创建、更新或删除视图。
语法
在 SQLite 中使用 VIEW 语句的语法如下:
/* 创建一个视图 */
CREATE VIEW [IF NOT EXISTS] view_name AS
SELECT column1, column2, column3, ...
FROM table_name
WHERE condition(s);
/* 删除一个视图 */
DROP VIEW view_name;
IF NOT EXISTS 是一个可选参数,仅当数据库中不存在视图时才有条件地创建视图。如果创建的视图已存在,则会引发错误。
示例:
考虑一个名为 Employee 的数据库表,其中包含以下记录:
EmpID | Name | City | Age | Salary | |
---|---|---|---|---|---|
1 | John | London | 25 | 3000 | |
2 | Marry | New York | 24 | 2750 | |
3 | Jo | Paris | 27 | 2800 | |
4 | Kim | Amsterdam | 30 | 3100 | |
5 | Ramesh | New Delhi | 28 | 3000 | |
6 | Huang | Beijing | 28 | 2800 |
创建视图
下面提到的SQLite语句用于在Employee表上创建一个视图,该表包含工资大于2800的员工的所有记录。
CREATE VIEW Employee_Salary_GT_2800 AS
SELECT * FROM Employee WHERE Salary > 2800;
查询视图
创建视图后,可以如下使用:
SELECT * FROM Employee_Salary_GT_2800;
这将产生如下所示的结果:
EmpID | Name | City | Age | Salary |
---|---|---|---|---|
1 | John | London | 25 | 3000 |
4 | Kim | Amsterdam | 30 | 3100 |
5 | Ramesh | New Delhi | 28 | 3000 |
删除视图
DROP VIEW 用于删除视图。
DROP VIEW Employee_Salary_GT_2800;
更改或更新视图
在 SQLite 中,无法更改或更新视图。不过,这可以通过先删除视图并创建包含更新内容的视图来实现。
下面的语句用于更新上面的视图,其中包含工资大于 2800 的员工和年龄的所有记录大于 25。
/* 删除视图 */
DROP VIEW Employee_Salary_GT_2800;
/* 创建一个新的视图 */
CREATE VIEW Employee_Salary_GT_2800 AS
SELECT * FROM Employee WHERE Salary > 2800 AND AGE > 25;
更新 VIEW 后,可以使用以下查询查看其内容:
SELECT * FROM Employee_Salary_GT_2800;
这将产生如下所示的结果:
EmpID | Name | City | Age | Salary |
---|---|---|---|---|
4 | Kim | Amsterdam | 30 | 3100 |
5 | Ramesh | New Delhi | 28 | 3000 |