MySQL之视图、存储过程、函数、触发器

一.视图(View)

1.视图概述

视图是一种虚拟存在的表,实际并不存在。其数据来自于数据库中自定义的表,实际是查询那些表动态生成的数据。

2.视图的使用

#语法:
CREATE [OR REPLACE] [ALGORITHM = {UNDEFINED | MERGE | TEMPTABLE}]
VIEW view_name [(column_list)]
AS select_statement
[WITH [CASCADED | LOCAL] CHECK OPTION]

举个栗子:
class表:
在这里插入图片描述
student表:
在这里插入图片描述
创建视图:

CREATE VIEW student_info_view 
 AS
SELECT s.id,s.name,s.class_id,c.class_name FROM student s ,class c WHERE s.id = c.id;

查看视图:
在这里插入图片描述
注:
更新视图中的数据实际更新到数据库中。

update student_info_view set name = 'hahaha' where id = 1;

在这里插入图片描述

二.存储过程(Procedure)

1.储存过程概述

存储过程是事先编译并存储于数据库的sql语句集合。

2.储存过程的使用

#语法:
CREATE PROCEDURE procedure_name ([proc_parameter[,...]])
begin
-- SQL语句
end ;

举个栗子:
数据库进行分表时,需要创建多张表,可以使用存储过程来创建。

#创建存储过程
CREATE PROCEDURE pro_create_student_table()
BEGIN
	DECLARE `@i` INT(11);
	DECLARE `@sqlstr` VARCHAR(2800);
	
	SET `@i` = 1;
	
	WHILE `@i` < 10 DO
		SET @sqlstr = CONCAT(
				"CREATE TABLE student_",`@i`," (
				`id` int(11) NOT NULL AUTO_INCREMENT COMMENT '学生id',
				`name` varchar(20) NOT NULL COMMENT '学生姓名',
				`age` smallint(6) DEFAULT NULL COMMENT '学生年龄',
				`sex` smallint(1) DEFAULT NULL COMMENT '学生性别 0:男 1:女',
				`class_id` int(11) DEFAULT NULL COMMENT '班级id',
				PRIMARY KEY (`id`),
				KEY `class_id` (`class_id`)
			) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=utf8"
		);
		PREPARE stmt FROM @sqlstr;
		
		EXECUTE stmt;
		
		SET `@i` = `@i` + 1;
	
	END WHILE;
 
END
#调用存储过程
CALL pro_create_student_table();

生成多张数据库表:
在这里插入图片描述

三.函数

1.函数概述

函数是事先编译并存储于数据库的sql语句集合。函数和存储过程的区别是,函数有返回值。函数分为自定义函数和内置函数。

2.自定义函数的使用

#语法:
CREATE FUNCTION function_name([param type ... ])
RETURNS type
BEGIN
...
END;

举个栗子:
计算学生表的数据总数。

#创建函数
CREATE FUNCTION fun_student_count()
RETURNS INT
BEGIN
	DECLARE `count` int(11);
	SELECT count(*) into count from student;
	RETURN count;
END
#调用函数
select fun_student_count();

在这里插入图片描述

四.触发器

1.触发器概述

触发器可以在数据库表进行Update(增、删、改)操作的之前或之后,触发sql语句的执行。

2.触发器的使用

#语法:
create trigger trigger_name
before/after insert/update/delete
on tbl_name
[ for each row ] -- 行级触发器
begin
trigger_stmt ;
end;

举个栗子:
创建student日志记录表:

create table student_logs(
	id int(11) not null auto_increment,
	operate_id int(11) not null comment '操作表的ID',
	operate_time datetime not null comment '操作时间',
	operation varchar(20) not null comment '操作类型, insert/update/delete',
	primary key(`id`)
)engine=innodb default charset=utf8;

创建触发器:

CREATE TRIGGER student_logs_insert_trigger
AFTER INSERT
ON student
FOR EACH ROW
BEGIN
	insert into student_logs(id,operate_id,operate_time,operation) VALUES(NULL,new.id,now(),"INSERT");
END

查看触发器:

SHOW TRIGGERS;

在这里插入图片描述
测试触发器:
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述


如有不对之处 敬请指正

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
存储过程存储函数触发器视图MySQL中都有各自的用途。 存储过程是一组预编译的SQL语句,可以在数据库创建存储,然后在需要的时候调用。它们的优点是可以实现模块化的设计,可以被多次调用,执行效率较高。存储过程通常用于执行复杂的数据库操作,例如数据的插入、更新、删除等。\[1\] 存储函数存储过程类似,也是一组预编译的SQL语句,但它们返回一个值。存储函数可以用于计算、转换数据等操作,并且可以在SQL语句中直接调用。\[2\] 触发器是一种特殊的存储过程,它在数据库中的表上定义,并在特定的事件发生时自动触发执行。触发器通常用于实现数据的约束、触发复杂的业务逻辑等。\[2\] 视图是一种虚拟的表,它是基于一个或多个表的查询结果构建的。视图可以简化复杂的查询操作,提供更方便的数据访问方式。视图通常用于隐藏敏感数据、简化数据查询、提供数据的不同展示方式等。\[2\] 综上所述,存储过程存储函数触发器视图MySQL中都有各自的用途,可以用于执行复杂的数据库操作、计算和转换数据、实现数据的约束和业务逻辑、以及提供方便的数据访问方式。 #### 引用[.reference_title] - *1* *2* [mysql中的视图触发器存储过程](https://blog.csdn.net/weixin_53002381/article/details/125796059)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down1,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [【MySQL基础】存储过程存储函数触发器视图](https://blog.csdn.net/qq_38149054/article/details/123298777)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值