SELECT必知必会_引擎,PROCEDURE,事务处理

news2025/1/15 19:39:12

书接上文,之前说了Mysql的SELECT部分,本片文章会重点介绍关于MySql的其他一些知识,也会是MySql必知必会的最后一篇。

首先,是Mysql中的增删改操作,对于测试岗来说,这部分知识相对来说不是那么重要,我一次性把一些基础部分贴一下。

1.INSERT
INSERT into table(id,name,small_name,age,sex)
values(1,'aa','bb',NULL.NULL)      插入一整行数据
values(......)                     插入多行,多个values,只需要一个INSERT

INSERT INTO table(a,b,c)
SELECT  (a,b,c)
FROM table_01      将所选数据导入table表

2.UPDATE
UPDATE table
SET  name='aa',age=24
WHERE id ='1';

3.DELETE
DELETE FROM table
WHERE id =1;

4.CREATE
CREATE TABLE table_name(
id         int            NOT NULL  AUTO_INCREMENT,   代表本列每新增一行,自动增加1
name  char(10)   NOT NULL ,     char是定长,varchar是不定长
sex     char(4)    NOT NULL,
PRIMARY KEY (id)  主键值必须唯一,如果使用多个列,则这些列的组合必须唯一
)
ENGINE = XXX引擎;
如果id不设置AUTO_INCREMENT的话,那就是用SLEECT COUNT然后再加以,这样浪费时间和资源。
同时,若有多个用户同时对表进行增加操作可能会出问题。

5.修改表
ALTER TABLE table_01          ALTER TABLE常用来定义外键
ADD name VARCHAR(50)
FOREIGN KEY (aaa) REFERENCE  xxx(aaa)
一个表创建好之后最好轻易不要改动,除非增加外键

6.删除/重命名   表
DROP  TABLE aaa;
RENAME TABLE aaa to bbb;

引擎

使用CREATE的时候,调用引擎创建表,在执行SELECT等操作时,该引擎会帮忙处理请求
不同的引擎有不同的特性

三种引擎:
InnoDB 可靠事务处理引擎,不支持全文本搜索 (事务处理:成批量的操作删除等等)
MEMORY 数据存在内存里,速度快,适用于临时表
MyISAM 性能高,支持全文本搜索,不支持事务处理

存储过程(PROCEDURE)

很多时候,实际中的处理过程,一条SQL语句完全无法满足要求,比如一个订单,要能正确处理,首先要保证库存中有货,其次有货的话要预定,确保这个物品不会重复售卖,订单成功后商品数量要减少,库存中没有物品要及时订货。
以上的情况是需要多条SQL语句来完成整个步骤的。多条SQL语句的组合,这就是存储过程。
存储过程一半是要比一条一条的执行其中的每条sql语句更快的。
创建存储过程:
CREATE  PROCEDURE aa   创建一个叫aa的存储过程
BEGIN
SELECT  **
WHERE ...;
END;
调用存储过程:
CALL aa();          调用存储过程aa
删除存储过程:
DROP PROCEDURE aa;

存储过程也可以传参:
在这里插入图片描述

游标

在 MySQL 中,存储过程或函数中的查询有时会返回多条记录,而使用简单的 SELECT 语句,没有办法得到第一行、下一行或前十行的数据,这时可以使用游标来逐条读取查询结果集中的记录。游标在部分资料中也被称为光标。

CREATE PROCEDURE aa()
BEGIN
DECLARE ordernum CURSOR
FOR                    为下面的SELECT定义一个游标,游标是被该SELECT检索出来的结果集
SELECT....
END;

OPEN/CLOSE  ordernum;         //打开,关闭游标

触发器

触发器是响应INSERT/DELETE/UPDATE后而自动触发的一条SQL语句,可以与PROCEDURE结合在一起
CREATE TRIGGER XXX AFTER/BEFORE INSERT ON product
FOR EACH ROW SELECT…   每一行都要执行操作

触发器不能更新或者覆盖,要更新,必须删了重新创建
DROP TRIGGER

事务处理

事务处理是一种机制。用来管理必须成批执行的SQL操作,确保不会在所有的操作执行完成前有中断操作。若整组sql无问题那就执行到底,若中间出错则会执行相应的回退。
前面说过两个引擎,MYISAM不支持事务处理,InnoDB支持

START TRANSACTION
SELECT...
DELETE..
UPDATE..
ROLLBACK;                      回退START到ROLLBACK之间的所有语句

可以把ROLLBACK换成COMMIT,如果语句都执行成功,COMMIT不生效,如果中间有句子执行报错,ROLLBACK会自动执行回滚功能

用户权限分配

CREATE USER shaoqiang;
GRANT SELECT ON database_aa TO shaoqiang;   给用户database_aa下所有表的查询权限
SHOW GRANTS FOR shaoqiang;            查询权限
REVOKE SELECT ON database_aa TO shaoqiang;     撤销权限

一些关于MySql性能提升的小细节

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/171466.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

案例分享 | AI助力肯尼亚“Sheng”语研究

你听说过一种叫做“Sheng”的语言吗?这是一种斯瓦希里语-英语俚语,主要使用者为肯尼亚内罗毕等城市地区的青年。近年来,随着“Sheng”的使用量不断增加,一家非盈利组织正在帮助更新该地区的社区信息资源,随时根据词汇中…

【6s965-fall2022】深度学习的效率指标

两个核心指标是计算和内存(Computation and Memory)。需要考虑的三个维度是存储、延迟和能耗(Storage, Latency, and Energy)。 延迟 Latency Latency max(Toperation,Tmemory)max(T_{operation}, T_{memory})max(Toperation​,Tmemory​) 能耗 Energy 内存访问比计算更消耗…

Softmax Loss、AAM-Softmax(ArcFace)、Sub-center ArcFace的PyTorch实现与代码解读

概述 说话人识别中的损失函数分为基于多类别分类的损失函数,和端到端的损失函数(也叫基于度量学习的损失函数),关于这些损失函数的理论部分,可参考说话人识别中的损失函数本文主要关注这些损失函数的实现,…

开源PPP软件PRIDE-PPPAR使用记录(二)解算网友发来的GNSS观测文件

最近有个网友发来了几个GNSS原始观测文件,想使用TerraPos处理一下看看结果。 TerraPos打开这几个文件,都报一个格式错误,见下图: 正在上传…重新上传取消​ 这个问题不难,解决之道就是按照上一篇文章的方法&#xf…

杭州到温州老家自驾路线优化与整理

欢迎关注更多精彩 关注我,学习常用算法与数据结构,一题多解,降维打击。 背景及义意义 背景 考虑到后续经常回老家,需要提前熟悉回家的路线。杭州和温州有很多快速路和国道与高速是基本相伴而行的,可以利用这些道路取…

在项目管理中,甘特图是最常用的工具之一

在项目管理中,为了能对项目过程进行监控,可视化进度管理,需要使用辅助工具来帮助我们管理项目,而甘特图则是其中最经常使用的工具之一。 甘特图更够清晰的反映项目各个阶段的计划,任务由谁负责,计划与实际…

mysql性能优化二

1 mysql 基本功能 1.1、mysql连接器的工作流程: 1.2、查看连接状态: show processlist; Note:客户端太长时间没动静 就自动断开 这个时间是由wait_timeout参数控制的,默认8h 长连接短链接 长连接是链接成功后,如果客户端持续有请求,则使用同一个链接[尽量使用长连接,因为每次…

通用NetCore前后端分离项目Linux系统部署步骤

最近参与的大部分项目都是NetCore API加SAP页面的形式,都是部署在linux系统上,本文记录新领的服务器的部署步骤。采用NetCore3.1,MySql数据库。 本文记录的程序名:myapp.dll 部署文件保存目录: 后台程序:/u…

SOLIDWORKS 2023新功能揭秘!装配体升级 阵列实例、配合错误修复、零件替换同步更新

SOLIDWORKS 2023全新面世,今天众联亿诚为大家带来SOLIDWORKS 2023装配体的新功能揭秘,SOLIDWORKS 2023对装配体进行功能增强,并且继续加强性能,让我们深入研究这些令人振奋的新功能吧!在装配体中阵列是一种常见的、节省…

jfow-core 代码分析

EntityNoName目录概述需求:设计思路实现思路分析1.code:2.code2:3.FLows4.frm5.code3:code4:EntityTreeAttrEntitiesNoNameenum:JUmp way参考资料和推荐阅读Survive by day and develop by night. talk for import biz , show your perfect code,full bu…

深度学习是什么?深度学习和神经网络的区别是什么

1、深度学习中什么是人工神经网络? 人工神经网络(Artificial Neural Network,即ANN )是从信息处理角度对人脑神经元网络进行抽象,是20世纪80年代以来人工智能领域兴起的研究热点,其本质是一种运算模型&…

C++——多态、异常、转化函数

目录 一、多态 二、异常 ​三、转换函数 3.1标准转换函数 3.2自定义转换函数 3.3隐式转换&#xff08;explicit&#xff09; 封装Thread类 一、多态 c支持用基类的指针指向派生类。 #include <iostream>using namespace std;class A{ public:A(){ }~A(){ cout<…

vite+vue3环境变量的配置

文章目录一、vite1. 环境变量2. env 文件2.1 环境加载优先级2.2 TypeScript 的智能提示3. 模式二、vue1. 开发环境2. 生产环境3. 在 vite.config.ts 使用环境变量一、vite vite官方文档&#xff1a;环境变量和模式 1. 环境变量 Vite 在一个特殊的 import.meta.env 对象上暴露…

爱普生LQ-635K针式打印机打链式打印纸设置自动切纸方法

链式打印纸还有别的叫法&#xff0c;折叠式打印纸、复写打印纸、等分打印纸、电脑打印纸...... 其实链式打印纸是打印纸的两边带孔的具有复写功能的一种。链式打印纸可连续打印&#xff0c;很合适大量的使用&#xff0c;节约放纸时间。 链式打印纸有整张、二等分、三等分的规格…

python比较两张图片并获取精准度

先安装依赖库dlib、face_recognition、cv2下载wheel文件&#xff1a;python3.6&#xff1a;dlib-19.7.0-cp36-cp36m-win_amd64.whl: https://drfs.ctcontents.com/file/1445568/768652503/68cb5d/Python/dlib-19.7.0-cp36-cp36m-win_amd64.whlpython3.7:dlib-19.17.99-cp37-cp3…

Spring中的IOC和AOP

IOC(控制反转)和AOP(面向方面编程)作为Spring框架的两个核心&#xff0c;很好地实现了解耦合。所以&#xff0c;简单来说&#xff0c;Spring是一个轻量级的控制反转&#xff08;IoC&#xff09;和面向切面&#xff08;AOP&#xff09;的容器框架。 spring的基本框架主要包含六…

2023年中职网络安全技能竞赛网页渗透(审计版)

三、竞赛任务书内容 (一)拓扑图 网页渗透测试 任务环境说明: 服务器场景:Server2127服务器场景操作系统:未知(封闭靶机)用户名:未知 密码:未知访问服务器网站目录1,根据页面信息完成条件,将获取到的flag提交;访问服务器网站目录2,根据页面信息完成条件,将获取…

SpringCloud(10):Hystrix请求缓存

1 类继承的方法来实现请求缓存 1.1 编写CacheCommand类 package com.study.service.hystrix;import com.netflix.hystrix.HystrixCommand; import com.netflix.hystrix.HystrixCommandGroupKey; import com.netflix.hystrix.HystrixCommandKey; import com.netflix.hystrix.H…

面试 | Python 自动化测试技术面试真题

本文为面试某公司测试开发&#xff0f;自动化测试工程师时的面试题笔记。 全部笔试内容没有全部写全&#xff0c;只贴通用性的技术相关的笔试面试题&#xff0c;至于测试理论和团队管理的问题&#xff0c;都是大同小异&#xff0c;也没什么实际的参考价值。 1.直接手写一个 Pyt…

智慧工地 | 数字孪生楼宇施工管理平台

随着科学技术的进步&#xff0c;时代的发展&#xff0c;越来越多的智慧应用走进我们身边&#xff0c;万物互联不再是口号。当前智慧城市建设的兴起&#xff0c;都在要求建筑实现与物联网结合&#xff0c;使其扩展和延伸到建筑物和任何物品之间进行交换和通信&#xff0c;也就是…