SQL基础随记2 视图 存储过程

 

View

  • CREATE/ALTER/DROP VIEW ViewName as SELECT(...)
  • 可以在视图的基础上继续创建视图,即,将之前创建的视图当做表名放在新视图的select语句中

  • 利用视图进行数据格式化(就是对字段进行重新组合与拼接)

    CREATE VIEW View_player_team AS
    SELECT CONCAT(player_name, '(' , team.team_name , ')') AS player_team
    FROM player JOIN team WHERE player.team_id = team.team_id
  • 视图具有安全性,因为视图是虚拟表,即使对视图做出了修改,也不会影响底层数据。

 

PROCEDURE

  • 存储过程就像“自定义函数”,它是SQL语句和流控制语句的集合,它可以接受参数,也可以返回参数。

  • 存储过程可以(不是一定)直接对底层数据表进行操作

  • CREATE PROCEDURE name(参数)
    BEGIN
    需要执行的过程
    END

    举例1,

    DELIMITER //
    
    CREATE PROCEDURE `存储过程名`(形参)
    BEGIN
    循环体
    END // DELIMITER;

    调用存储过程举例

    CALL `存储过程名`(实参);
    select @(out参数)
    • DELIMITER是将分隔符变为 // (也可以使用其他的),因为流控制语句中的语句需要;分割,此举是避免混淆

    • 开头和结尾的DELIMITER都是另起一行mysql shell

    • 存储过程名用的不是单引号,是反引号,也可以不加

    • 流控制语句

      DECLIARE --- 声明变量
      SET --- 初始化,赋值
      IF...THEN...;END IF; REPEAT...UNTIL...END REPEAT --- 满足UNTIL后面的表达式则退出循环
      WHILE...DO...END WHILE --- 先判断条件,满足则循环
      labelName:LOOP...(IF...THEN...LEAVE labelName;END IF;)...END LOOP labelName;
      CONTINUT;
      BREAK;
      RETURN;
      GOTO (label) WAITFOR TIME 'time' --- 在某个时刻执行
      WAITFOR DELAY 'time' --- 延迟某个时间执行
      SELECT...INTO... --- 将查询表中的结果放入变量中
  • 参数类型

    • IN --- 传入参数,无法返回,不写参数类型默认为IN
    • OUT --- 将存储过程的计算结果放入OUT参数中并用于返回
    • INOUT --- 既用于传入参数又可以将结果存入该参数中用于返回
  • PROCEDURE的优点

    • 安全性强,设定存储过程的时候可以设置对用户的使用权限
    • 执行效率快,在MySQL数据库服务器端执行
    • 通过封装,减少网络传输量
  • PROCEDURE的缺点 --- 阿里等公司不推荐使用的原因

    • 调试困难,仅少部分DBMS支持调试
    • 可移植性差
    • 版本管理困难
    • 不适合高并发场景 --- 高并发需要减小数据库压力,可能会采用分库分表的方式且对拓展性要求高。在这种情况下,存储过程变得难以维护且会增加数据库的压力

 

procedure 举例1 按某个字段对表进行查询

  • 查看已有测试表

    mysql> SELECT * FROM t;
    +----+------+
    | Id | nums |
    +----+------+
    | 1 | 2 |
    +----+------+
    1 row in set (0.00 sec)

    创建存储过程

    mysql> DELIMITER //
    mysql> CREATE PROCEDURE `findByNums`(IN n int)
    -> BEGIN
    -> SELECT * FROM t WHERE nums = n;
    -> END //
    Query OK, 0 rows affected (0.03 sec)

    检验

    mysql> DELIMITER ;
    mysql> CALL findByNums(2);
    +----+------+
    | Id | nums |
    +----+------+
    | 1 | 2 |
    +----+------+
    1 row in set (0.03 sec) Query OK, 0 rows affected (0.03 sec)

    (传入不同参数)

    mysql> CALL findByNums(1);
    Empty set (0.00 sec) Query OK, 0 rows affected (0.00 sec)

     

  • 查询存储过程

    mysql> SELECT * FROM mysql.proc WHERE db = 'test' AND type = 'procedure';

 

procedure 举例2 计算累和结果

  • 使用存储过程传入/传出参数查询输出

    mysql> delimiter //
    mysql> create procedure `add_sum`(in n int, out result int)
    -> begin
    -> declare i int;
    -> declare sum int;
    -> set i = 1;
    -> set sum = 0;
    -> while i < n do
    -> set sum = sum + i;
    -> set i = i + 1;
    -> end while;
    -> end //
    Query OK, 0 rows affected (0.00 sec) mysql> delimiter ;
    mysql> call add_sum(50,@result);
    Query OK, 0 rows affected (0.00 sec) mysql> select @result;
    +---------+
    | @result |
    +---------+
    | 1225 |
    +---------+
    1 row in set (0.00 sec)
  • 无法直接@存储过程中的变量

    mysql> create procedure `add_sum_procedure`(in n int)
    -> begin
    -> declare i int;
    -> declare sum int;
    -> set i = 1;
    -> set sum = 0;
    -> while i < n do
    -> set sum = sum + i;
    -> set i = i + 1;
    -> end while;
    -> end //
    Query OK, 0 rows affected (0.00 sec) mysql> delimiter ;
    mysql> call add_sum_procedure(10);
    Query OK, 0 rows affected (0.01 sec) mysql> select @sum;
    +------+
    | @sum |
    +------+
    | NULL |
    +------+
    1 row in set (0.01 sec)

查询所有存储过程/视图 等等

 

SQL基础随记2 视图 存储过程的更多相关文章

  1. SQL基础随记3 范式 键

    SQL基础随记3 范式 键 什么是范式?哈,自己设计会使用但是一问还真说不上来.遂将不太明晰的概念整体下   什么是 & 分类 范式(NF),一种规范,设计数据库模型时对关系内部各个属性之间的 ...

  2. SQL基础随记1 SQL分类 常用函数 ALL ANY EXISTS IN 约束

    SQL基础随记1 SQL分类 常用函数 ALL ANY EXISTS IN 约束   其实这里知识不难,只是好久不接触突然被问的话有时还真的一时答不上,自己写一遍胜过盲扫.当然,也有些常读常新的地方会 ...

  3. SQL基础(3)-索引/触发器/视图操作

    本文只列出索引,触发器,视图的简单操作语句 1.索引 a.创建 create index idx_name on fdh_client_info(name); --普通索引(单列索引) create ...

  4. sql:MySQL 6.7 表,视图,存储过程结构查询

    #数据库MySQL 6.7 use sakila; #查询表名 show tables; # SELECT TABLE_NAME,TABLE_ROWS FROM INFORMATION_SCHEMA. ...

  5. 四、SQL基础知识--约束和视图

    --创建约束的方式 --一.在字段创建时将约束添加到字段之后 CREATE TABLE ZYJ_YUESHU( ZYJ_ID VARCHAR(20) NOT NULL PRIMARY KEY, --创 ...

  6. SQL点滴17—使用数据库引擎存储过程,系统视图查询,DBA,BI开发人员必备基础知识

    原文:SQL点滴17-使用数据库引擎存储过程,系统视图查询,DBA,BI开发人员必备基础知识 在开发过程中会遇到需要弄清楚这个数据库什么时候建的,这个数据库中有多少表,这个存储过程长的什么样子等等信息 ...

  7. [SQL基础教程] 5-1视图

    [SQL基础教程] 5-1视图 视图和表 从SQL角度看视图就是一张表 视图与表的差别 表保存了实际的数据,视图保存的是SELECT语句: 视图的优点 节省存储空间: 将常用的Select 语句保存成 ...

  8. T——SQL基础语句(定义变量,赋值,取值,分支,循环,存储过程)

    T--SQL基础语句 1.定义变量: declare @变量名 数据类型 ; declare @a int ; declare @b  nvarchar(10) ; 2.赋值: 法1:set @变量名 ...

  9. SQL基础学习_04_视图

    视图 1. 视图的创建     视图就是保存好的SELECT语句,这些SELECT语句执行之后会产生新的表,所以在SQL中,视图和表是不做差别对待的,也就是SQL也可以对视图做一些操作:     由于 ...

随机推荐

  1. 面试三轮我倒在了一道sql题上——sql性能优化

    一.前言 最近小农在找工作,因为今年疫情的特殊原因,导致工作不是特别好找,所以一旦有面试电话,如果可以,都会去试一试,刚好接到一个面试邀请,感觉公司还不错,于是就确定了面试时间,准备了一下就去面试了. ...

  2. React 为什么要把事件挂载到 document 上 & 事件机制源码分析

    前言 我们都知道 React 组件绑定事件的本质是代理到 document 上,然而面试被问到,为什么要这么设计,有什么好处吗? 我知道肯定不会是因为虚拟 DOM 的原因,因为 Vue 的事件就能挂载 ...

  3. JAVA第三次blog总结

    JAVA第三次blog总结 0.前言 这是我们在博客园上第三次写博客,也是本学期最后一次的JAVA学习大总结.现在我们的JAVA已经接近尾声了,对于编程思想和方法的改变依旧是难点,但是经过这一段时间的 ...

  4. 00-03.kaliLinux-vi粘贴复制功能配置

    KaliLinux在xShell的vim中默认是无法复制和粘贴的,需要做如下配置后才能使用: 方法一 进入vim命令行模式,输入: :set mouse=c #进入Command-line 模式 然后 ...

  5. 关于wifi营销的看过来

    亲测可用.对于一个开发者来说,终于如获至宝.详情联系qq2455994690.源码可二开.包括微信一键关注上网,手机验证码上网.

  6. Source insight 提示: it is not currently available for write access

    点击阅读原文 使用sourceinsight编辑linux内核文件后不能保存,并且弹出窗口揭示:Error: "Z:\linux\kernel\kernel-2.6.13\scripts\k ...

  7. 用python简单爬取一个网页

    1打开编辑器 2撸几行代码 import urllib.request import urllib.error def main(): askURl("http://movie.douban ...

  8. Python基础002---基础知识

    一.标识符 标识符是自己定义的,是开发人员在程序中自己定义的一些符号和名称,如变量名.函数名等.在 Python 里,标识符由字母(区分大小写).数字.下划线组成,且数字不能开头.常用的命名方法有小驼 ...

  9. ASP.NET处理管道之防盗链

    盗链就是在用户向网站a请求网站资源时,网站a将网站资源的路径填写为b网站资源的地址,用户将直接看到网站a上显示着网站b的资源,从而造成盗链. 要防止盗链,就要用到处理管道中的技术 在相应的模块类中: ...

  10. python中那些鲜为人知的功能特性

    经常逛GitHub的可能关注一个牛叉的项目,叫 What the f*ck Python! 这个项目列出了几乎所有python中那些鲜为人知的功能特性,有些功能第一次遇见时,你会冒出 what the ...