当前位置: 首页 > news >正文

MySQL中的视图和触发器

SQL 视图


1 ) 概述

  • 在mysql中,视图是一个非真实存在的虚拟表
  • 其本质是,根据sql语句获取动态的数据集,并为其命名
  • 用户使用时只需使用名称,即可获取结果集,并可以将其当做表来使用

2 )用法示例

2.1 比较麻烦的sql

select*
from (select nid,name from tb1 where nid > 2) as A
whereA.name > 'alex'

2.2 使用视图简化以便后续可能得复用

  • 上面子查询, 比较麻烦,可以考虑创建成视图
  • 创建视图的示例
    • create view v1 as select nid,name from tb1 where nid > 2
  • 使用视图
    • select * from v1;
    • 上面这句sql的本质是 select * from (select nid,name from tb1 where nid > 2) as v1
  • 删除视图
    • drop view v1;
  • 修改视图
    • alter view v1 as sql语句
  • 需要注意的是
    • 基于视图只能查询, 不能执行增加,修改,删除
    • 如果源表发生变化,视图表也会发生变化
  • 注意:视图在开发阶段实际使用的频率不是很高

SQL触发器


1 ) 概述

  • 比如,数据库中有两张表(或多张表),程序需要对某张表操作的时候
  • 同时需要对另一张表进行增加,删除,修改等操作,在这时候就可以使用触发器
  • 触发器是存储在数据库里,程序就不用操作另外一张表了,直接在操作目标表
  • 另外的一张表的同步可以交给你写的触发器
  • 可以在各个场景中使用

2 )用法示例

2.1 插入前,插入后

-- 插入前
create trigger tri_before_insert_tb1 before insert on tb1 for each row
begin-- ... 这里写你的逻辑
end-- 插入后
create trigger tri_after_insert_tb1 after insert on tb1 for each row
begin-- ... 这里写你的逻辑
end

2.2 删除前,删除后

-- 删除前
create trigger tri_before_delete_tb1 before delete on tb1 for each row
begin-- ... 这里写你的逻辑
end-- 删除后
create trigger tri_after_delete_tb1 after delete on tb1 for each row
begin-- ... 这里写你的逻辑
end

2.3 更新前,更新后

-- 更新前
create trigger tri_before_update_tb1 before update on tb1 for each row
begin-- ... 这里写你的逻辑
end-- 更新后
create trigger tri_after_update_tb1 after update on tb1 for each row
begin-- ... 这里写你的逻辑
end
  • 触发器里的 FOR EACH ROW 是针对每一行的
    • 如果针对这张表每一行做操作,每一行都会触发一次触发器
    • 比如,我有10行数据,在删除每一行的时候,都会触发这个触发器
  • 删除触发器
    • drop trigger tri_after_insert_tb1; 这里删除定义的一个触发器

3 )综合示例

  • 场景:你的数据库中有两张表分别是 t1 和 t2 需要触发器
  • 需求和触发器
    • 在 t1 表插入数据之前,先在 t2 表中插入一行数据
      delimiter $$
      create trigger tri_before_insert_t1 before insert on t1 for each row
      beginif NEW.name = 'alex' theninsert into t2(name) values(NEW.name); -- NEW 是新插入的数据
      end if;end $$
      delimiter;
      
    • 在 t1 表中删除数据之后,再在t2表中插入一行数据
      delimiter $$
      create trigger tri_after_insert_t1 after delete on t1 for each row
      beginif OLD.name = 'alex' theninsert into t2(id, name) values(OLD.id, OLD.name);
      end if;end $$
      delimiter;
      
    • 这里,NEW 是新数据,OLD 是原数据
  • 触发器在业务开发中用的不多,这些一般程序都能搞定
  • 习惯上,能用程序方便搞定的,不用数据库自带的触发器

相关文章:

MySQL中的视图和触发器

SQL 视图 1 ) 概述 在mysql中,视图是一个非真实存在的虚拟表其本质是,根据sql语句获取动态的数据集,并为其命名用户使用时只需使用名称,即可获取结果集,并可以将其当做表来使用 2 )用法示例 2.1 比较麻烦…...

uView-UI v2.x常见问题整理

为了更好的给大家提供 uView UI 的技术支持,uView UI 团队整理常见问题文档,大家可以阅读查找常见的问题解决办法。 uView 2.x 文档 https://www.uviewui.com uView 1.x 文档 https://v1.uviewui.com uView UI uni-app 主页 DCloud 插件市场 uVie…...

MBTI职业性格测试 28题(免费版)

MBTI职业性格测试概述 MBTI是现在国际上最为流行的测试工具,利用MBTI职业性格测试,可以清楚地找到自己的性格特点以及兴趣爱好,方便于对职业进行规划、以及改善人际关系。其主要应用心理学常识对个性做出判断,提炼出动力、信息收…...

Springcloud 微服务实战笔记 Ribbon

使用 Configurationpublic class CustomConfiguration {BeanLoadBalanced // 开启负载均衡能力public RestTemplate restTemplate() {return new RestTemplate();}}可看到使用Ribbon,非常简单,只需将LoadBalanced注解加在RestTemplate的Bean上&#xff0…...

CSS基础笔记-04cascade-specificity-inheritance

CSS基础笔记系列 《CSS基础笔记-01CSS概述》《CSS基础笔记-02动画》CSS基础笔记-03选择器 前言 Cascading Style Sheets,关键就在于这个cascading,对于这个术语理解,感觉对于我这种CSS新手有点儿不太friendly。本文记录下我对这个术语的理…...

Spring应用的部署与管理

一、前言 部署是将开发好的应用发布到服务器上,使其能够被用户访问的关键步骤。Spring框架提供了灵活的部署选项,本文将介绍Spring应用的常见部署方式和一些建议,帮助开发者顺利将应用投放到生产环境。 二、传统部署方式:WAR包 传…...

B端产品经理学习-需求挖掘

B端产品需求挖掘 目录 识别和管理干系人 决策人和负责人需求挖掘 针对用户进行需求挖掘 用户访谈结果整理 B端产品的需求来源是非常复杂的,要考虑多个方面;如果你是一个通用性的产品,要考虑市场、自身优劣势、干系人。而定制型B端产品会…...

整数规划基本原理

1.1 定义 规划中的变量(部分或全部)限制为整数时,称为整数规划。若在线性规划模型中,变量限制为整数,则称为整数线性规划。目前所流行的求解整数规划的方法,往往只适用于整数线性规划。目前还没有一种方法…...

秋招复习之堆

目录 前言 堆 堆的常用操作 堆的实现(大根堆) 1. 堆的存储与表示 2. 访问堆顶元素 3. 元素入堆 4. 堆顶元素出堆 Top-k 问题 方法一:遍历选择 方法二:排序 方法三:堆 总结 前言 秋招复习之堆。 堆 「堆 heap…...

算法训练营Day36(贪心-重叠区间)

都算是 重叠区间 问题,大家可以好好感受一下。 都属于那种看起来好复杂,但一看贪心解法,惊呼:这么巧妙! 还是属于那种,做过了也就会了,没做过就很难想出来。 不过大家把如下三题做了之后&#…...

如何利用Oracle官方网站不登录账号下载和安装非最新版本的JDK(版本自由选择)

一、JDK概述 JDK(Java Development Kit)是Java开发工具集,是针对Java编程语言的软件开发环境。它包含了Java编译器、JRE(Java运行时环境)以及其他一些用于开发、调试和测试Java应用程序的工具,是Java开发人…...

税法相关的基础知识

文章目录 税法原则1.税法基本原则2.税法适用原则 来和大家聊聊税法相关的基础知识 税法原则 1.税法基本原则 2.税法适用原则...

ListNode 2487. 从链表中移除节点,单调栈的应用

一、题目 1、题目描述 给你一个链表的头节点 head 。 移除每个右侧有一个更大数值的节点。 返回修改后链表的头节点 head 。 2、接口描述 /*** Definition for singly-linked list.* struct ListNode {* int val;* ListNode *next;* ListNode() : val(0), next(nu…...

vue3中pdf打印问题处理

1 get请求参数问题 之前的请求是post得不到参数,今天发现的问题很奇怪,从前端进入网关,网关居然得不到参数。 前端代码 const print () > {let linkUrlStr proxy.$tool.getUrlStr(proxy.$api.invOrder.psiInvOrder.printSalOutstock,{a…...

如何向嵌入式设备中添加tcpdump工具

说明:tcpdump是一个在网络设备调试中一个非常重要的工具,它并不像hexdump等工具集成在busybox里面,也不像其他的软件一样只需要依赖linux标准的库就可以实现,它需要pcap相关的库和加密的相关库。 本文主要是基于realtek 83系列的…...

伦茨科技Apple Find My认证芯片-ST17H6x芯片

深圳市伦茨科技有限公司(以下简称“伦茨科技”)发布ST17H6x Soc平台。成为继Nordic之后全球第二家取得Apple Find My「查找」认证的芯片厂家,该平台提供可通过Apple Find My认证的Apple查找(Find My)功能集成解决方案。…...

uni-app 前后端调用实例 基于Springboot 数据列表显示实现

锋哥原创的uni-app视频教程: 2023版uniapp从入门到上天视频教程(Java后端无废话版),火爆更新中..._哔哩哔哩_bilibili2023版uniapp从入门到上天视频教程(Java后端无废话版),火爆更新中...共计23条视频,包括:第1讲 uni…...

python渗透工具编写学习笔记:10、网络爬虫基础/多功能编写

目录 前言 10.1 概念 10.2 调度器/解析器 10.3 存储器/去重器 10.4 日志模块 10.5 反爬模块 10.6 代理模块 前言 在渗透工具中,网络爬虫有着不可忽视的作用,它能够快速而精准的搜寻、提取我们所需要的信息并按照我们所需要的格式排列,…...

Python武器库开发-武器库篇之子域名扫描器开发(四十一)

Python武器库开发-武器库篇之子域名扫描器开发(四十一) 在我们做红队攻防或者渗透测试的过程中,信息收集往往都是第一步的,有人说:渗透的本质就是信息收集,前期好的信息收集很大程度上决定了渗透的质量和攻击面,本文将…...

通俗易懂的15个Java Lambda表达式案例

文章目录 1. **实现Runnable接口**:2. **事件监听器**(如Swing中的ActionListener):3. **集合遍历**(使用forEach方法):4. **过滤集合**(使用Stream API):5. …...

十七:爬虫-JS逆向(上)

1、什么是JS、JS反爬是什么?JS逆向是什么? JS:JS全称JavaScript是互联网上最流行的脚本语言,这门语言可用于HTML 和 web,更可广泛用于服务器、PC、笔记本电脑、平板电脑和智能手机等设备。JavaScript 是一种轻量级的编程语言。JavaScript 是…...

How to implement anti-crawler strategies to protect site data

How to implement anti-crawler strategies to protect site data 信息校验型反爬虫User-Agent反爬虫Cookie反爬虫签名验证反爬虫WebSocket握手验证反爬虫WebSocket消息校验反爬虫WebSocket Ping反爬虫 动态渲染反爬虫文本混淆反爬虫图片伪装反爬虫CSS偏移反爬虫SVG映射反爬虫字…...

王国维的人生三境界,这一生至少当一次傻瓜

一、人生三境界 古今之成大事业、大学问者,必经过三种之境界。“昨夜西风凋碧树,独上高楼,望尽天涯路。”此第一境也。“衣带渐宽终不悔,为伊消得人憔悴。”此第二境也。“众里寻他千百度,蓦然回首,那人却…...

Jmeter二次开发实操问题汇总(JDK问题,jar包问题)

前提 之前写过一篇文章:https://qa-lsq.blog.csdn.net/article/details/119782694 只是简单尝试了一下生成一个随机手机号码。 但是如果在工作中一个实际场景要用的二次开发,可能会遇到一些问题。 比如这样一个场景: Mobile或者前端调用部分…...

网络安全B模块(笔记详解)- 数字取证

数据分析数字取证-attack 1.使用Wireshark查看并分析Windows 7桌面下的attack.pcapng数据包文件,通过分析数据包attack.pcapng找出恶意用户的IP地址,并将恶意用户的IP地址作为Flag(形式:[IP地址])提交; 解析:http.request.method==POST ​ Flag:[172.16.1.102] 2.继续…...

阿里云服务器8080端口安全组开通图文教程

阿里云服务器8080端口开放在安全组中放行,Tomcat默认使用8080端口,8080端口也用于www代理服务,阿腾云atengyun.com以8080端口为例来详细说下阿里云服务器8080端口开启教程教程: 阿里云服务器8080端口开启教程 阿里云服务器8080端…...

vmlinux, vmlinux.bin, bzImage; cmake的find_package(Clang)新增了哪些变量( 比较两次记录的所有变量差异)

vmlinux, vmlinux.bin, bzImage cd /bal/linux-stable/ file vmlinux #vmlinux: ELF 32-bit LSB executable, Intel 80386, version 1 (SYSV), statically linked, BuildID[sha1]=b99bbd9dda1ec2751da246d4a7ae4e6fcf7d789b, not stripped #文件大小 20MB, 19940148Bfile ar…...

webpack配置入门

webpack是需要一定配置才能使用的,否则无任何效果。在开始webpack学习之前必须理解以下5个核心概念。 5大核心配置 1.entry(入口) webpack从那个文件开始打包,支持单文件入口(vue和react脚手架单入口)和多文件入口 2.output(输…...

Elasticsearch 8.X进阶搜索之“图搜图”实战

Elasticsearch 8.X “图搜图”实战 1、什么是图搜图? "图搜图"指的是通过图像搜索的一种方法,用户可以通过上传一张图片,搜索引擎会返回类似或者相关的图片结果。这种搜索方式不需要用户输入文字,而是通过比较图片的视…...

LLM之RAG实战(十三)| 利用MongoDB矢量搜索实现RAG高级检索

想象一下,你是一名侦探,身处庞大的信息世界,试图在堆积如山的数据中找到隐藏的一条重要线索,这就是检索增强生成(RAG)发挥作用的地方,它就像你在人工智能和语言模型世界中的可靠助手。但即使是最…...

秦皇岛海三建设董事长/常州seo收费

Redis 1:数据库应用的发展历程 ​ 单机数据库时代:一个应用,一个数据库实例。 ​ Mencached(缓存)时代: ​ 读写分离时代 ​ 分表分库时代(集群) ​ 关系型数据库:oracle,mysq…...

个人网站需要多大空间/网站排名监控工具

2019独角兽企业重金招聘Python工程师标准>>> 自从DHTML出现以来,微软对DHTML功能的加强就没有停止过,在微软最新的游览器Internet Explorer 5.5的的IE5.5增加了许多新的样式表内容,对滚动条的样式进行修改也是其中之一&#xff0c…...

公司网站建设小知识/怎样在百度上做免费推广

区分hiredis、hiredis-py、redis-py redis官网Github:https://github.com/redis,这里会看到两个项目: hiredis --> 是一个C语言的redis客户端库hiredis-py --> 是Python语言包装了hiredis的redis客户端库 Andy McCurd的Github&#x…...

页面模板怎么修改/seo 网站排名

因为题目的数据处理起来比较乱,我们平时在学习的时候一定要学习这种规范的数据存储方式: 上图中,nodes那个数据,只是在for循环中暂存的,他把结果过渡到res的结果集中。...

江苏建设准考证打印在哪个网站/产品怎么做市场推广

HashMap深入理解 HashMap基于哈希表的 Map 接口的实现。允许使用 null 值和 null 键。不保证映射的顺序,特别是它不保证该顺序恒久不变。 HashMap的底层主要是基于数组和链表来实现的,它之所以有相当快的查询速度主要是因为它是通过计算散列码来决定存…...

三五互联网站建设垃圾/网络营销的方法

2019独角兽企业重金招聘Python工程师标准>>> 最大文件描述符 ulimit -SHn 1024000 echo "ulimit -SHn 1024000" >> /etc/rc.d/rc.local source /etc/rc.d/rc.local 内核参数优化/etc/sysctl.conf #关闭ipv6 net.ipv6.conf.all.disable_ipv6 1 n…...