mysql学习记录

insert into table_nameA(字段名) select 字段名 from table_nameA(按照一般的select语句格式进行)

通过此语句,可以根据需要抓取数据组成新记录落表

存储过程

创建:

CREATE PROCEDURE pro_name(

IN orderNo INT,

OUT param1 DECIMAL(8,2)

BEGIN

select sum(price*num)

INTO param1

from TableA;

END;

存储过程可以不定义返回数;存储过程处理写在begin end 块中,IN表示入参,OUT表示出参,即处理后返回给调用方的结果

以上的例子调用情况如下:

CALL pro_name(20005,@total)--即使存储过程无入参出参,仍需要带上()

此时,可以直接使用@total

select @total

此语句,计算出来的就是一个订单的商品合计价格的值

在存储过程中可以使用declare定义中间变量

修改MySQL中的存储过程,可以使用 ALTER PROCEDURE 语句,内容格式同新增

删除存储过程:drop procedure pro_name,不需要带()

触发器:

以上是创建触发器的例子,触发器只针对表的insert、update以及delete操作生效,在操作前与操作后的关键字分别为BEFORE和AFTER,对视图以及临时表不起作用,select无需触发器

insert触发器是建立一张NEW虚拟表记录,delete触发器是建立一个OLD表进行进行记录,update触发器则是用old表接旧值,用new表接新值;old中的记录不可更改,new中的记录值在落表后可能被更改

触发器不能修改,需要做任何改动,删了重建即可,名称唯一,删除:drop trigger neworder

相关推荐
fake_ss1982 小时前
AI时代学习全栈项目开发的新范式
java·人工智能·学习·架构·个人开发·学习方法
Upsy-Daisy2 小时前
AI Agent 项目学习笔记(二):Spring AI 与 ChatClient 主链路解析
人工智能·笔记·学习
长谷深风1113 小时前
索引提速秘籍【个人八股】
mysql·b+树·索引·索引设计原则·存储引擎优化·索引维护成本·字段选择策略
山峰哥3 小时前
SQL慢查询调优实战:从全表扫描到索引覆盖的完整复盘
前端·数据库·sql·性能优化
Irene19913 小时前
在 WSL 中下载安装 MySQL,连接到 SQLyog(MySQL 安装在 WSL vs Windows 本地对比)
mysql·wsl
C+++Python4 小时前
C++ 进阶学习完整指南
java·c++·学习
sulikey5 小时前
个人Linux操作系统学习笔记2 - gcc与库的理解
linux·笔记·学习·操作系统·gcc·
南浦别a5 小时前
第102天--时隔多日的书写
学习·程序人生
Jackyzhe5 小时前
从零学习Kafka:消费者组重平衡
分布式·学习·kafka
吃好睡好便好5 小时前
在Creo中如何把新建零件文件时的默认模板设置为公制单位
学习·3d·信息可视化