使用CREATE VIEW语句创建视图
语法格式为:
CREATE [ALGORITHM={UNDEFINED | MERGE | TEMPTABLE}] VIEW 视图[列名]
AS
select_statement
[WITH [CASCADED | LOCAL] CHECK OPTION
]
说明:
ALGORITH,:可选参数,表示视图算法,其取值有三。其中UNDEFINED表示自动选择算法。MERGE表示将使用的视图语句和视图定义合并起来,是的视图定义的某一部分取代语句对应的部分。TEMPTABLE表示将视图的结果存入临时表,然后用临时表来换行语句。
select_statement:表示视图定义的SELECT语句。
WITH [CASCADED | LOCAL] CHECK OPTION:可选参数,表示更新视图时要保证在该视图的权限范围内。其中CASCADED是默认值,表示更新视图时要满足所有相关视图和表的条件,LOCAL表示更新视图时满足该视图本身定义的条件即可。
例如:创建名为news的视图,用来显示用户的商品信息,包括用户名,商品名称,购买数量,商品价格。
CREATE VIEW news(用户名,商品名称,购买数量,商品价格)
AS
SELECT A.UNAME,C.GDNAME,B.SCNUM,C.GDPRICE
FROM USERS A JOIN SCAARS B JOIN GOODS C
ON A.UID=B.UID AND C.GDID=B.GDID;
SHOW TABLE STATUS语句
SHOW TABLE STATUS语句用来查看视图的基本信息,语法为:
SHOW TABLE STATUS LIKE ‘视图名’;
DESC语句
DESC语句或者DESCCRIBE语句可以查看视图的结构信息,语法为:
DESC 视图名;
SHOW CREATE VIEW语句
SHOW CREATE VIEW语句可以查看视图的定义文本,语法为:
SHOW CREATE VIEW 视图名;
修改视图
CREATE OR REPLACE VIEW 语句
语法为:
CREATE OR REPLACE
[ALGORITHM={UNDEFINED | MERGE | TEMPTABLE}] VIEW 视图[列名]
AS
select_statement
[WITH [CASCADED | LOCAL] CHECK OPTION
]*
例如:修改news视图,用于查询用户名姓名和电话
CREATE OR REPLACE VIEW NEWS(姓名,电话)
AS
SELECT UNAME,UPHONE
FROM USERS
ALTER VIEW 语句
语法为:
ALTER [ALGORITHM={UNDEFINED | MERGE | TEMPTABLE}]
VIEW 视图[列名]
AS
select_statement
[WITH [CASCADED | LOCAL] CHECK OPTION
删除视图
语法为: DROP VIEW [ IF EXISTE] 视图名
其中EXISTE是可选参数,用于判断视图是否存在,存在则执行。