首页 > 其他分享 >视图、存储过程、触发器 整理

视图、存储过程、触发器 整理

时间:2024-12-28 16:18:51浏览次数:1  
标签:语句 ... 触发器 end 存储 视图 select

// 视图
// 视图就是基表的映射
// 创建视图
// 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] 视图名称 [,视图名称]...;

// 由于视图只是基表的映射,所以所有对于视图的修改操作都会在基表上生效

// 检查选项
// with [(cascaded | local)] check option
// 如果创建视图时增加以上语句,insert数据时mysql会检查该条数据是否满足视图要求,不满足则组织该条请求
// cascaded会检查是否满足该视图以及该视图依赖的所有视图(不管是否加了cascaded)的条件
// local只会检查是否满足当前视图的条件

// 要使视图可更新,视图中的行与基础表中的行必须存在一对一关系,如果视图中包含一下任何一项,则该视图不可更新:
// 聚合函数或窗口函数(sum(), min(), max(), count()等)
// distinct
// group by
// having
// union 或者 union all

// 视图作用
// 简单:视图可以简化用户对数据的理解,也可以简化他们的操作。那些被经常使用的查询可以被定义为视图,从而使得用户不必为以后的操作每次指定全部的条件
// 安全:数据库可以授权,但是不能授权到数据库特定行和特定的列上。通过视图用户只能查询和修改他们能看到的数据
// 数据独立:视图可帮助用户屏蔽真实表结构变化带来的影响。

// ----------------------------------------------------------------------------------------------------------------------------------------------
// 存储过程
// 定义:____是实现经过编译并存储在数据库中的一段sql语句的集合,调用存储过程可以简化应用开发人员的很多工作,减少数据在数据库和应用服务器之间的传输
// 本质上就是数据库sql语言层面的代码封装与重用
// 类似与创建一个函数

// 创建
// create procedure 存储过程名称([参数列表])
// begin
// --sql语句
// end;
// 注意:在命令行中创建存储过程时,mysql会识别sql语句中的';'从而提前结束sql创建存储过程sql语句,我们需要使用delimiter方法自定义结束符

delimiter $$

create procedure p1()
begin
select * from user;
end$$

delimiter ;

// 调用
// call 名称([参数]);

// 查看指定数据库存储过程及状态信息
// select * from information_schema.routines where routine_schema = 'XXX';

// 查询某个存储过程的定义语法
// show create procedure 存储过程名称;

// 删除
// drop procedure [if exists] 存储过程名称;

// 变量
// 系统变量
// 系统变量分为全局变量global与会话变量session
// 查看系统变量
// show [session | global] variables;
// show [session | global] variables like '...';
// select @@[session | global] 系统变量名; --查看指定变量的值

// 设置系统变量
// set [session | global] 系统变量名 = 值;
// set @@[session | global] 系统变量名 = 值;

// 修改全局变量值之后重启mysql服务器系统变量还是会恢复到默认值
// 想要永久生效需要到/etc/my.cnf中配置

// 用户自定义变量
// 用户变量的作用域只在当前连接

// 赋值
// 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

// 局部变量
// 局部变量只能在其声明的begin...end块内使用
// 声明
// declare 变量名 变量类型[default...];
// 变量类型有int,bigint,char,varchar,date,time等

// 赋值
// set 变量名 = 值;
// set 变量名 := 值;
// select 字段名 into 变量名 from 表名...;
create procedure p2()
begin
declare stu_count int default 0;
select count(*) into stu_count from student;
select stu_count;
end;

call p2();

// if条件判断
// if 条件1 then
// .....
// elseif 条件2 then
// .....
// else
// .....
// end if;

// 存储过程参数
// in:传入参数
// out:返回值
// inout:既是传入参数又是返回值
// create procedure 存储过程名称([in/out/inout 参数名 参数类型])
// begin
// --sql语句
// end;

// case语句
// 语法一
// case case_value
// when when_value1 then statement_list1
// [when when_value2 then statement_list2]...
// [else statement_list]
// end case;

// 语法二
// case
// when search_condition then statement_list1
// [when search_condition2 then statement_list2]...
// [else statement_list]
// end case;

// while语法
// while 条件 do
// --sql语句
// end while;

// repeat语法
// repeat
// --sql语句
// until 判断条件
// end;

// repeat类似于do...while 语句,与之不同的是repeat判断的是满足条件退出循环

// loop语法
// leave等价于break
// iterate等价于continue
// 以上二者都需要配合着标记进行使用
// loop就是死循环类似于while(1) 或者是go中while
sum : loop
if n <= 0 then
leave sum;
end if;
set total := total + n;
set n := n - 1;
end loop sum;

// 游标
// 游标是能够存储一张表的数据类型
// 声明
// declare 游标名称 cursor for select语句;

// 打开游标
// 在使用游标之前必须打开游标
// open 游标名称;

// 获取游标记录
// fetch 游标名称 into 变量[, 变量]...;

// 关闭游标
// close 游标名称;

// 游标的声明必须在局部变量声明之前
// 游标遍历时会自动向下一行遍历

// 条件处理程序
// 类比于try
// declare handler_action handler for condition_value [, condition_value]... statement;
// handler_action
// continue: 继续执行当前程序
// exit: 终止执行当前程序
// condition_value
// sqlstate sqlstate_value: 状态码,如02000
// sqlwarning: 所有01开头的sqlstate代码的简写
// not found: 所有以 开头的sqlstate代码的简写
// sqlexception: 所有没有被sqlwarning或not found捕获的sqlstate代码的简写
// statement
// 代表判定成功之后执行的操作

// -------------------------------------------------------------------------------------------------------------------------
// 存储函数

// 存储函数就是有返回值的存储过程,存储函数的参数只能是in类型
// create function 存储函数名称([参数列表(必须是in类型)])
// returns type [characteristic...]
// begin
// --sql语句
// return...;
// end;

// characteristic
// deterministic: 相同的输入参数总是产生相同的结果
// no sql: 不包含sql语句
// reads sql data: 包含读取数据的语句,但不包含写入数据的语句

// 存储函数比较类似于一般变成语言函数的写法
create function solve(n int)
returns int deterministic
begin
declare addd int default 0;
while n > 0 do
set addd := addd + n;
set n := n - 1;
end while;
return addd;
end;

select solve(100);

drop function if exists solve;

// -------------------------------------------------------------------------------------------------------------------------
// 触发器

// 与表相关的数据库对象,指的是在insert/update/delete操作之后,触发并执行触发器中定义的sql语句集合。用于保证数据的完整性,日志记录,数据校验等
// 使用别名来引用触发器中发生改变的记录内容分别为 old与new,现在触发器只支持行级触发,不支持语句级触发。

// 创建
// create trigger trigger_name
before/after insert/update/delete on tbl_name for each row --行级触发器
begin
trigger_stmt;
end;

// 查看
// show triggers;

// 删除
// drop trigger [schema_name.]trigger_name; --如果没有指定schema_name,默认为当前数据库

标签:语句,...,触发器,end,存储,视图,select
From: https://www.cnblogs.com/caigouyizhi/p/18637604

相关文章

  • 江科大STM32学习:10 DMA直接存储器取存
    参考STM32F0xxx参考手册>2.存储器和总线架构<>10.DMA<1.DMA简介2.存储器映像类型起始地址存储器用途ROM0x08000000程序存储器Flash存储C语言编译后的程序代码0x1FFFF000系统存储器存储BootLoader,用于串口下载0x1FFFF800选项字节存储一些独立于程序代码的配置参数RAM......
  • 计算机数据存储形式和编码
    计算机是如何存储数据的   数值类型的数据(整数、浮点数)   字符类型的数据(字符串)   数据类型:整型(byte\short\int\long)、浮点型(float\double)、字符型(char)、布尔型(boolean)  java  整型(short\int\long)、浮点型(float\double)、字符型(char)......
  • PSRAM(Pseudo SRAM,伪静态随机存取存储器)与SRAM
    PSRAM(PseudoSRAM,伪静态随机存取存储器)与SRAM(静态随机存取存储器)存在多方面区别:###技术原理-**SRAM**:利用双稳态触发器(由多个晶体管组成)来存储数据。只要电源持续供电,触发器就能保持其存储的状态,不需要额外的刷新操作,数据可以随时被读取和写入。-**PSRAM**:本质上是一种特殊的D......
  • linux中,redis哨兵和数据持久化存储
    redis哨兵:"主从同步增强架构","读写分离","高可用" 1.概念 是Redis主从同步的增强架构,可以实现Redis主从同步的读写分离和高可用 2.特性: 1、可以承接客户端连接,但不存储数据 2、实现Redis主从复制组的监控 3、实现Redis主从的读写分离 4、Redis主从复制组的故......
  • SwiftUI 简单时间线视图开发教程
    SwiftUI简单时间线视图开发教程本教程详细介绍了如何实现一个时间线视图,并逐步分析代码的设计思路。我们会特别分析时间线中连接线的实现,探讨其连续性如何保持以及偏移量计算的原因。简单时间线视图1.整体视图结构TimeLineView是整个时间线组件的入口,包含以下......
  • 用Apache Doris实现实时向量存储与查询
    文章目录概要整体架构流程技术名词解释技术细节小结概要提示:这里可以添加技术概要例如:openAI的GPT大模型的发展历程。整体架构流程提示:这里可以添加技术整体架构例如:在语言模型中,编码器和解码器都是由一个个的Transformer组件拼接在一起形成的。技术......
  • 使用 Astra DB 作为向量存储的快速入门教程
    老铁们,今天我们聊聊如何使用AstraDB作为一个向量存储。这玩意儿是基于ApacheCassandra®打造的无服务器数据库,支持向量存储,并且通过一个简易的JSONAPI提供服务。说白了,就是让你的数据库能更智能化地处理数据分析。技术背景介绍AstraDB提供了一个名为langchain......
  • Kafka日志存储全解析
    文章目录1.1.日志存储结构1.1.1.日志文件结构1.1.2.topic1.1.3.partition1.1.4.segment索引文件1.1.5.message结构1.1.6.message查找过程1.2.存储策略1.2.1.顺序写1.2.2.页缓存1.2.3.零拷贝1.2.4.缓存机制1.3.日志格式演变1.3.1.V0版本1.3.2.V1版本1.3.3.V0/V1消息集......
  • CDS标准视图:功能位置 I_FunctionalLocation
    视图名称:I_FunctionalLocation视图类型:基础视图代码:点击查看代码@EndUserText.label:'FunctionalLocation'@Analytics:{dataCategory:#DIMENSION}@VDM.viewType:#BASIC@AbapCatalog:{sqlViewName:'IFUNCTLLOCATION',compiler.compareFilter,preserveK......
  • wevtutil 是 Windows 操作系统中的一个命令行工具,用于管理和操作事件日志。事件日志是
     wevtutil是Windows操作系统中的一个命令行工具,用于管理和操作事件日志。事件日志是操作系统、应用程序和系统服务等记录的重要信息文件,它们用于存储系统运行时的信息、警告和错误,帮助管理员排查问题和进行故障排除。wevtutil提供了强大的功能来查看、导出、清理、配置和管......