SQL-4大板块(存储过程、函数、视图、触发器)

一、 存储过程(做复杂运算)

1.做复杂运算,是对变量做运算;

2.可以对多个表进行update、insert、delete、select、query;

3.可以在最终结果返回多个表,但是对对接环境有苛刻要求,比如:VB不支持接收返回多个表

4.当一个查询语句无法实现,或者语句查询速度很慢时,想提高效率就会用到存储过程。先把需要的数据沉淀到结果表中,然后直接查询结果表,以此提高效率。

5.存储过程,为第三方提供了可以处理业务的接口,返回的是结果集;

6.存储过程只在创建时进行编译,以后执行存储过程都不需要再重新编译,而一般SQL语句每执行一次就会编译一次,所以使用存储过程的执行速度会高。

二、 函数(标量函数、表值函数)

1.标量函数:一定是有输入参数的,但个数不限,至少一个。

输入参数,返回数值

对于标量值函数来说,是需要加上所有者的,即dbo.

2.表值函数:输入参数,返回一个表

对于表值函数调用是不需要所有者的,即dbo.,只要写函数名称就可以

3.函数可以作为查询语句的一个部分来调用

三、 视图(单查询语句)

1.不可以声明变量,从创建视图的那一刻起,就把它当做是一个单查询语句

2.使用视图计算值,如汇总值

3.视图就是一个表或多个表的映射,一般只做查询使用。如想要的数据在两个表中,但又不想每次都写关联语句去查询,那么就可以创建一个视图,以后也可以只查这个视图

4.在保密性方面,视图只展示我们需要的字段,其他字段信息不会外露

5.视图,不能处理业务的接口,返回的是结果集;

四、 触发器(管理客户端无法实现约束限制的数据)

1.客户端有时无法对一批数据中的某些特殊数据做限制,此时可以用触发器,当SQL检测到这些特殊数据想要传进来时,触动触发器,对这些特殊数据做相应处理、

2.做数据库操作时,想达到数据同步的效果,就可以用触发器。比如:向A表插入数据时,同时向B表插入。这样触发器在每次往A表插入数据时,就会自动往B表里插数据了。

3.触发器是特殊的存储过程,存储过程需要程序调用,而触发器会自动执行。

相关推荐
马克Markorg2 小时前
常见的向量数据库和具有向量数据库能力的数据库
数据库
Coder_Boy_4 小时前
技术让开发更轻松的底层矛盾
java·大数据·数据库·人工智能·深度学习
helloworldandy4 小时前
使用Pandas进行数据分析:从数据清洗到可视化
jvm·数据库·python
数据知道6 小时前
PostgreSQL 故障排查:如何找出数据库中最耗时的 SQL 语句
数据库·sql·postgresql
qq_12498707536 小时前
基于SSM的动物保护系统的设计与实现(源码+论文+部署+安装)
java·数据库·spring boot·毕业设计·ssm·计算机毕业设计
枷锁—sha6 小时前
【SRC】SQL注入WAF 绕过应对策略(二)
网络·数据库·python·sql·安全·网络安全
Coder_Boy_6 小时前
基于SpringAI的在线考试系统-考试系统开发流程案例
java·数据库·人工智能·spring boot·后端
Gain_chance6 小时前
35-学习笔记尚硅谷数仓搭建-DWS层最近n日汇总表及历史至今汇总表建表语句
数据库·数据仓库·hive·笔记·学习
此生只爱蛋7 小时前
【Redis】主从复制
数据库·redis
马猴烧酒.7 小时前
【面试八股|JAVA多线程】JAVA多线程常考面试题详解
java·服务器·数据库