MySQL数据库---笔记4

MySQL数据库---笔记4

  • 一、视图
    • 1.1、介绍及基本语法
    • 1.2、检查选项
    • 1.3、更新及作用
  • 二、存储过程
    • 2.1、介绍
    • 2.2、基本语法
    • 2.3、变量
      • 2.3.1、系统变量
      • 2.3.2、用户自定义变量
      • 2.3.2、局部变量
    • 2.4、if判断
    • 2.5、参数

一、视图

1.1、介绍及基本语法

  • 创建
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] 视图名称[视图名称]...

1.2、检查选项

当使用WTHCHECK OPTION子句创建视图时,MySQL会通过视图检查正在更改的每个行,例如插入,更新,删除,以使其符合视图的定义。MySQL允许基于另一个视图创建视图,它还会检查依赖视图中的规则以保持一致性。为了确定检查的范围,mysql提供了

两个选项:
CASCADEDLOCAL,默认值为CASCADED

CASCADED:

如果加入了CASCADED,不仅会检查该行的对于视图添加的条件,还会对检查该视图所依赖的视图的条件,若有一个条件不满足则会发生报错

LOCAL:

如果加入了LOCAL,在添加,修改数据时,会检查加入了改行语句的条件,如果依赖的视图中也添加了LOCAL则检查该行的条件。如果某个视图为添加LOCAL则不会进行检查条件

1.3、更新及作用

  • 视图的更新

要使视图可更新,视图中的行与基础表中的行之间必须存在一对一的关系。如果视图包含以下任何一项,则该视图不可更新:

  1. 聚合函数或窗口函数(SUM()MIN()MAX()COUNT()等)
  2. DISTINCT
  3. GROUP BY
  4. HAVING
  5. UNION 或者 UNION ALL

作用

  • 简单

视图不仅可以简化用户对数据的理解,也可以简化他们的操作。那些被经常使用的查询可以被定义为视图,从而使得用户不必为以后的操作每次指定全部的条件。

  • 安全

数据库可以授权,但不能授权到数据库特定行和特定的列上。通过视图用户只能查询和修改他们所能见到的数据

  • 数据独立

视图可帮助用户屏蔽真实表结构变化带来的影响。

二、存储过程

2.1、介绍

存储过程是事先经过编译并存储在数据库中的一段SQL语句的集合,调用存储过程可以简化应用开发人员的很多工作,减少数据在数据库和应用服务器之间的传输,对于提高数据处理的效率是有好处的。

存储过程思想上很简单,就是数据库SQL语言层面的代码封装与重用。

特点

  • 封装,复用
  • 可以接受参数,也可以返回数据
  • 减少网络交互,效率提升

2.2、基本语法

  • 创建
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语句的结束符。

2.3、变量

2.3.1、系统变量

  • 变量

系统变量是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 中配置。

2.3.2、用户自定义变量

  • 变量
    用户定义变量是用户根据需要自己定义的变量,用户变量不用提前声明,在用的时候直接用“@变量名”使用就可以。其作用域为当前连接。

用户定义变量是用户根据需要自己定义的变量,用户变量不用提前声明,在用的时候直接用“@变量名”使用就可以。其作用域为当前连接。

  • 赋值
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 表名;
  • 使用
    SELECT @var_name ;

注意:
用户定义的变量无需对其进行声明或初始化,只不过获取到的值为NULL。

2.3.2、局部变量

局部变量是根据需要定义的在局部生效的变量,访问之前,需要DECLARE声明。可用作存储过程内的局部变量和输入参数,局部变量的范围是在其内声明的BEGIN ...END块。

  • 声明
DECLARE 变量名 变量类型[DEFAULT ...];

变量类型就是数据库字段类型:INT、BIGINT、CHAR、VARCHAR、DATE、TIME等。

  • 赋值
SET 变量名 =;
SET 变量名 :=;
SELECT 字段名 INTO 变量名 FROM 表名...;

2.4、if判断

语法:

IF 条件1 THEN
	...
ELSEIF 条件2 THEN   --可选
	...
ELSE 				--可选
	...
END IF;

2.5、参数

类型 含义 备注
IN 该类参数作为输入,也就是需要调用时传入值 默认
OUT 该类参数作为输出,也就是该参数可以作为返回值
INOUT 既可以作为输入参数,也可以作为输出参数

你可能感兴趣的:(数据库,mysql,笔记)