本文整理自网络,侵删。
目录
- 系列教程
- 一、视图
- 1、视图的创建
- 2、查看视图定义
- 3、删除视图
- 二、存储函数
- 1、系统函数
- 2、自定义函数(user-defined function:UDF)
- 三、存储过程
- 四、触发器
- 总结
系列教程
MySQL系列之开篇 MySQL关系型数据库基础概念
MySQL系列之一 MariaDB-server安装
MySQL系列之二 多实例配置
MySQL系列之三 基础篇
MySQL系列之四 SQL语法
MySQL系列之六 用户与授权
MySQL系列之七 MySQL存储引擎
MySQL系列之八 MySQL服务器变量
MySQL系列之九 mysql查询缓存及索引
MySQL系列之十 MySQL事务隔离实现并发控制
MySQL系列之十一 日志记录
MySQL系列之十二 备份与恢复
MySQL系列之十三 MySQL的复制
MySQL系列之十四 MySQL的高可用实现
MySQL系列之十五 MySQL常用配置和性能压力测试
一、视图
视图:VIEW,虚表,保存有实表的查询结果,实际数据不保存在磁盘
物化视图:实际数据在磁盘中有保存,加快访问,MySQL不支持物化视图
基表:视图依赖的表
视图中的数据事实上存储于“基表”中,因此,其修改操作也会针对基表实现。其修改操作受基表限制。
注意:修改视图时是修改的原表
1、视图的创建
CREATE VIEW view_name AS select_statement
MariaDB [testdb]> CREATE VIEW v_students AS SELECT id,name,ages FROM students; MariaDB [testdb]> SELECT * FROM v_students; +----+---------------+------+ | id | name | ages | +----+---------------+------+ | 1 | tom | 26 | | 2 | jerry | 19 | | 3 | maria | 19 | | 4 | xiaolongnv | 18 | | 5 | dongfangbubai | 28 | | 6 | ouyangfeng | 56 | +----+---------------+------+
2、查看视图定义
SHOW CREATE VIEW view_name
MariaDB [testdb]> SHOW CREATE VIEW v_students\G View: v_students Create View: CREATE ALGORITHM=UNDEFINED DEFINER=`root`@`localhost` SQL SECURITY DEFINER VIEW `v_students` AS select `students`.`id` AS `id`,`students`.`name` AS `name`,`students`.`ages` AS `ages` from `students`
MariaDB [testdb]> SHOW TABLE STATUS LIKE 'v_students'\G Name: v_students Comment: VIEW #判断一个表是否是视图
3、删除视图
DROP VIEW [IF EXISTS] view_name [, view_name] ...
MariaDB [testdb]> DROP VIEW v_students;
二、存储函数
说明: 参数可以有多个,也可以没有参数,必须有且只有一个返回值。
1、系统函数
参考官方文档:https://dev.mysql.com/doc/refman/5.7/en/func-op-summary-ref.html
2、自定义函数(user-defined function:UDF)
自定义函数保存在mysql.proc表中
- 查看UDF列表 SHOW FUNCTIOIN STATUS;
- 查看UDF定义 SHOW CREATE FUNCTION function_name
- 删除UDF DROP FUNCTION function_name
- 调用自定义函数语法 SELECT function_name(parameter_value,...)
- 为变量赋值 SET parameter_name = value[,parameter_name = value...]
- 查看变量 SELECT INTO parameter_name
MariaDB [testdb]> DELIMITER // #修改结束符为// MariaDB [testdb]> CREATE FUNCTION addTwoNumber(x SMALLINT UNSIGNED, Y SMALLINT UNSIGNED) -> RETURNS SMALLINT -> BEGIN -> DECLARE a, b SMALLINT UNSIGNED DEFAULT 10; -> SET a = x, b = y; -> RETURN a+b; -> END// Query OK, 0 rows affected (0.01 sec) MariaDB [testdb]> DELIMITER ; #定义完函数后再修改回来 MariaDB [testdb]> SELECT addTwoNumber(8,9); #调用UDF求和 +-------------------+ | addTwoNumber(8,9) | +-------------------+ | 17 | +-------------------+
三、存储过程
存储过程把经常使用的SQL语句或业务逻辑封装起来,预编译保存在数据库中,当需要时从数据库中直接调用,省去了编译的过程。提高了运行速度同时降低网络数据传输量
相关阅读 >>
yaf的安装_配置yaf的rewrite规则_生成一个最简单的yaf项目
更多相关阅读请进入《mysql》频道 >>
数据库系统概念 第6版
机械工业出版社
本书主要讲述了数据模型、基于对象的数据库和XML、数据存储和查询、事务管理、体系结构等方面的内容。
转载请注明出处:木庄网络博客 » MySQL系列之五 视图、存储函数、存储过程、触发器
相关推荐
评论
管理员已关闭评论功能...