CREATE [OR REPLACE] VIEW 视图名称[(列名列表)] AS SELECT 语句 [WITH [ CASCADED | LOCAL ] CHECK OPTION]
查看创建视图语句:SHOW CREATE VIEW 视图名称;
查看视图数据:SELECT *FROM 视图名称...... ;
方式一:CREATE [OR REPLACE] VIEW 视图名称 [(列名列表)]AS SELECT 语句 [WITH [ CASCADED | LOCAL] CHECK OPTION]
方式二:ALTER VIEW 视图名称 [(列名列表)]AS SELECT 语句 [WITH [ CASCADED | LOCAL ] CHECK OPTION]
DROP VIEW [IF EXISTS] 视图名称[视图名称]...
当使用WTHCHECK OPTION子句创建视图时,MySQL会通过视图检查正在更改的每个行,例如插入,更新,删除,以使其符合视图的定义。MySQL允许基于另一个视图创建视图,它还会检查依赖视图中的规则以保持一致性。为了确定检查的范围,mysql提供了
两个选项:
CASCADED
和LOCAL
,默认值为CASCADED
。
CASCADED:
如果加入了CASCADED
,不仅会检查该行的对于视图添加的条件,还会对检查该视图所依赖的视图的条件,若有一个条件不满足则会发生报错
LOCAL:
如果加入了LOCAL
,在添加,修改数据时,会检查加入了改行语句的条件,如果依赖的视图中也添加了LOCAL
则检查该行的条件。如果某个视图为添加LOCAL
则不会进行检查条件
要使视图可更新,视图中的行与基础表中的行之间必须存在一对一的关系。如果视图包含以下任何一项,则该视图不可更新:
SUM()
、MIN()
、MAX()
、COUNT()
等)DISTINCT
GROUP BY
HAVING
UNION
或者 UNION ALL
作用
视图不仅可以简化用户对数据的理解,也可以简化他们的操作。那些被经常使用的查询可以被定义为视图,从而使得用户不必为以后的操作每次指定全部的条件。
数据库可以授权,但不能授权到数据库特定行和特定的列上。通过视图用户只能查询和修改他们所能见到的数据
视图可帮助用户屏蔽真实表结构变化带来的影响。
存储过程是事先经过编译并存储在数据库中的一段SQL语句的集合,调用存储过程可以简化应用开发人员的很多工作,减少数据在数据库和应用服务器之间的传输,对于提高数据处理的效率是有好处的。
存储过程思想上很简单,就是数据库SQL语言层面的代码封装与重用。
特点
CREATE PROCEDURE 存储过程名称 ([参数列表])
BEGIN
-- SQL语句
END ;
CALL 名称 ([参数]);
SELECT* FROM INFORMATION_SCHEMA.ROUTINES WHERE ROUTINE_SCHEMA='xxx';--查询指定数据库的存储过程及状态信息
SHOW CREATE PROCEDURE 存储过程名称; --查询某个存储过程的定义
DROP PROCEDURE [ IF EXISTS] 存储过程名称;
注意:在命令行中,执行创建存储过程的SQL时,需要通过关键字delimiter
指定SQL语句的结束符。
系统变量是MySQL服务器提供,不是用户定义的,属于服务器层面。分为全局变(GLOBAL) 、会话变量(SESSION)。
SHOW [ SESSION | GLOBAL] VARIABLES; -- 查看所有系统变量
SHOW [ SESSION| GLOBAL] VARIABLES LIKE '...';--可以通过LIKE模糊匹配方式查找变量
SELECT @@[SESSION |GLOBAL].系统变量名; --查看指定变量的值
SET [ SESSION |GLOBAL] 系统变量名=值;
SET @@[SESSION | GLOBAL] 系统变量名=值;
注意:
如果没有指定SESSION/GLOBAL,默认是SESSION,会话变量。
mysql服务重新启动之后,所设置的全局参数会失效,要想不失效,可以在/etc/my.cnf 中配置。
用户定义变量是用户根据需要自己定义的变量,用户变量不用提前声明,在用的时候直接用“@变量名”使用就可以。其作用域为当前连接。
SET @var_name = expr [, @var_name = expr ] ... ;
SET @var_name := expr [, @var_name := expr] ...;
SELECT @var_name := expr [ @var_name := expr ]... ;
SELECT 字段名 INTO @var_name FROM 表名;
注意:
用户定义的变量无需对其进行声明或初始化,只不过获取到的值为NULL。
局部变量是根据需要定义的在局部生效的变量,访问之前,需要DECLARE声明。可用作存储过程内的局部变量和输入参数,局部变量的范围是在其内声明的BEGIN ...END
块。
DECLARE 变量名 变量类型[DEFAULT ...];
变量类型就是数据库字段类型:INT、BIGINT、CHAR、VARCHAR、DATE、TIME等。
SET 变量名 = 值;
SET 变量名 := 值;
SELECT 字段名 INTO 变量名 FROM 表名...;
语法:
IF 条件1 THEN
...
ELSEIF 条件2 THEN --可选
...
ELSE --可选
...
END IF;
类型 | 含义 | 备注 |
---|---|---|
IN | 该类参数作为输入,也就是需要调用时传入值 | 默认 |
OUT | 该类参数作为输出,也就是该参数可以作为返回值 | |
INOUT | 既可以作为输入参数,也可以作为输出参数 |