事务,MySQL函数和索引详解

文章目录

    • 事务简介
    • 提交方式
      • 手动提交事务
    • 事务执行流程
      • 修改事务的默认提交方式
    • 事务原理
    • 四大特性
    • 隔离级别
  • MySQL函数
    • 常见的日期函数
    • 判断函数case when
    • 字符串函数
    • 数字函数
  • MySQL性能(了解)
  • 索引
    • 概念
    • 分类
    • MySQL索引语法
    • 数据结构(了解)
      • B+Tree
      • B+Tree好处
    • 优缺点
      • 优势
      • 劣势
    • 创建原则

事务简介

是一个不可分割的逻辑单元,可以在一个事务中书写多行SQL语句,这些SQL语句会做一个整体,要么同时成功,要么同时失败
MySQL数据库默认:一行SQL语句就会自动提交(表中数据持久更新)

提交方式

  1. 手动提交事务:先开启,再提交
  2. 自动提交事务(默认的):在执行一条sql语句时自动开启及提交一次事务 mysql是默认

手动提交事务

开启事务:start transaction
提交事务:commit
回滚事务:rollback

事务执行流程

Snipaste_2024-04-12_14-28-31.png

修改事务的默认提交方式

查看事务的默认提交方式
select @@autocommit;
0代表手动提交,1代表自动提交
修改默认提交方式
set @@autocommit = 0;
注意:如果修改了手动提交,增删改之后需要commit

事务原理

Snipaste_2024-04-12_16-03-05.png

四大特性

  1. 原子性 A

原子是不可分割的最小操作单位,要么同时成功,要么同时失败

  1. 一致性 C

事务操作前后,数据总量不变

  1. 隔离性 I

多个用户并发访问数据库,一个用户的事务不能被其他用户的事务干扰,多个并发的事务之间要相互隔离

  1. 持久性 D

当事务提交或回滚后,数据库会持久化的保存数据

隔离级别

Snipaste_2024-04-12_16-21-36.png
Snipaste_2024-04-12_16-21-57.png

MySQL函数

常见的日期函数

Snipaste_2024-04-12_16-51-46.png

判断函数case when

格式一
Snipaste_2024-04-12_17-04-12.png
格式二
Snipaste_2024-04-12_17-04-35.png
通常和select语句一起搭配使用
Snipaste_2024-04-12_17-06-09.png

字符串函数

Snipaste_2024-04-12_17-06-48.png

数字函数

Snipaste_2024-04-12_17-07-54.png

MySQL性能(了解)

Snipaste_2024-04-12_17-18-00.png

索引

概念

就是帮助MySQL高效获取数据的数据结构
本质:是数据结构(B+Tree)
1开始

分类

  1. 主键索引

主键约束(非空+唯一)+提高查询效率

  1. 唯一索引

唯一约束+提高效率

  1. 普通索引

仅提高效率

  1. 组合索引

多个字段组成索引

MySQL索引语法

  1. 创建索引

create index 索引名 on 表名 (字段); 创建普通索引
create unique index 索引名 on 表名(字段);唯一索引
create index 索引名 on 表名(字段1,字段2,…); 普通组合
create unique index 索引名 on 表名(字段1,字段2,…); 唯一组合索引
注意
如果在同一张表中创建多个索引,要保证索引名不能重复

  1. 在已有表的字段上修改表时指定

添加一个主键,索引值唯一非null,默认索引名primary
alter table 表名 add primary key (字段);
添加唯一索引,(null出现多次),默认索引名为字段名
alter table 表名 add unique (字段);
添加普通索引,默认索引名为字段名
alter table 表名 add index (字段);

  1. 创建表时指定

create table student{
id int primary key auto_increment, – 主键索引
name varchar(20),
telephone varchar(11) unique, – 唯一索引
birthday date,
index (name) – 普通索引
};

数据结构(了解)

B+Tree

Snipaste_2024-04-12_17-18-00.png

B+Tree好处

Snipaste_2024-04-12_20-35-26.png

优缺点

优势

1) 类似于书籍的目录索引,提高数据检索的效率,降低数据库的IO成本。IO次数越多,效率越低。
2) 索引底层就是排序,通过索引列对数据进行排序,降低数据排序的成本,降低CPU的消耗。

劣势

  • 在数据库建立过程中,需花费较多的时间去建立并维护索引,特别是随着数据总量的增加,所花费的时间将不断递增。
  • 在数据库中创建的索引需要占用一定的物理存储空间,这其中就包括数据表所占的数据空间以及所创建的每一个索引所占用的物理空间。
  • 在对表中的数据进行修改时,例如对其进行增加、删除或者是修改操作时,索引还需要进行动态的维护,这给数据库的维护速度带来了一定的麻烦。

创建原则

  1. 字段内容可识别度不能低于70%,字段内数据唯一值的个数不能低于70%
    例如:一个表数据只有50行,那么性别和年龄哪个字段适合创建索引,明显是年龄,因为年龄的唯一值个数比较多,性别只有两个选项 。性别的识别度是50%。
    2. 经常使用where条件搜索的字段,例如user表的id name等字段。
    3. 经常使用表连接的字段(内连接、外连接),可以加快连接的速度。
    4. 经常排序的字段 order by,因为索引已经是排过序的,这样一来可以利用索引的排序,加快排序查 询速度。
    注意: 那是不是在数据库表字段中尽量多建索引呢?
    肯定是不是的。因为索引的建立和维护都是需要耗时的 创建表时需要通过数据库去维护索引,添加记录、更新、修改时,也需要更新索引,会间接影响数据库的效率。

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

python中time库的time.time()函数的作用是什么?

python中time库的time.time()函数的作用是什么? 作用:Python time time() 返回当前时间的时间戳(1970纪元后经过的浮点秒数)。 time()方法语法:time.time() #!/usr/bin/python # Write Python 3 code in this onlin…

【LeetCode】动态规划类题目详解

所有题目均来自于LeetCode,刷题代码使用的Python3版本 动态规划 问题分类 如果某一个问题有重叠的子问题,则使用动态规划进行求解是最有效的。 动态规划中每一个状态一定是由上一个状态推导出来的,这一点区别于贪心算法 动态规划五部曲 确…

【JMeter】JMeter控制RPS

一、前言 ​ RPS (Request Per Second)一般用来衡量服务端的吞吐量,相比于并发模式,更适合用来摸底服务端的性能。我们可以通过使用 JMeter 的常数吞吐量定时器来限制每个线程的RPS。对于RPS,我们可以把他理解为我们的TPS,我们就不…

初识SpringMVC

一、什么是MVC MVC是一种软件架构模式(是一种软件架构设计思想,不止Java开发中用到,其它语言也需要用到),它将应用分为三块: M:Model(模型)V:View&#xff08…

Centos7 K8S 集群 - kubeadm搭建方式

机器准备 搭建环境是centos7, 四核心4G内存四台机器 一个master节点,一个etcd,两台node 机器名称IP 地址master192.168.1.127node1192.168.1.129node2192.168.1.130node3192.168.1.131 机器时间同步 各节点时间要求精确同步,可以直接联网…

游标的定义和类型

Oracle从入门到总裁:​​​​​​https://blog.csdn.net/weixin_67859959/article/details/135209645 游标的基本概念 游标从字面上理解为游动的光标,可以使用 Excel 表格来想象游标的作用,游标指向每一行,通过游标访问每行数据。 在 Orac…

6.3Python之字典的内置方法

1、创建字典 dict.fromkeys() :可将列表、元组、集合转为字典 knowledgeL [语文, 数学, 英语] scoresD1 dict.fromkeys(knowledgeL, 60) print(scoresD1) knowledgeT (Chinese, Math, English) scoresD2 dict.fromkeys(knowledgeT, 60) print(scoresD2) knowl…

【Web】CTFSHOW-ThinkPHP5-6反序列化刷题记录(全)

目录 web611 web612 web613-622 web623 web624-626 纯记录exp&#xff0c;链子不作赘述 web611 具体分析&#xff1a; ThinkPHP-Vuln/ThinkPHP5/ThinkPHP5.1.X反序列化利用链.md at master Mochazz/ThinkPHP-Vuln GitHub 题目直接给了反序列化入口 exp: <?ph…

Web中使用Weblogic用户

WebLogic用户&#xff0c;组设置 1. 登录weblogic console, domain结构中选择Security Realms&#xff0c;显示安装时默认创建的Realm &#xff1a; myrealm 2. 点击myrealm, 选择 users and Group&#xff0c; 追加用户和组 选择既存的权限组追加到新规的组中&#xff0c;赋予…

面试:如何设计一个注册中心?

大家好&#xff0c;我是田哥 上周&#xff0c;一位群里的朋友反馈面试情况&#xff1a; 今天&#xff0c;给大家分享如何设计一个注册中心。其实这个问题&#xff0c;我之前在知识星球里分享过&#xff0c;可能是因为时间比较久了&#xff0c;加上这位朋友加入不久&#xff0c;…

力扣HOT100 - 160. 相交链表

解题思路&#xff1a; /*** Definition for singly-linked list.* public class ListNode {* int val;* ListNode next;* ListNode(int x) {* val x;* next null;* }* }*/ public class Solution {public ListNode getIntersectionNode(ListNode headA, ListNode headB) {if…

雨云:不一样的服务器体验

引言 在当今数字化时代&#xff0c;服务器已经成为了许多企业和个人不可或缺的一部分。无论是建立网站、存储数据还是运行应用程序&#xff0c;都需要一个稳定可靠的服务器来支持。然而&#xff0c;在众多的服务器提供商中&#xff0c;选择一个适合自己需求的并不容易。今天我要…

spispi

数据手册里面有这么一段解释&#xff0c;就是说如果我们开启了看门狗&#xff0c;那么LSI就会跟随强制打开&#xff0c;等待LSI稳定之后就可以自动为独立看门狗提供时钟了。所以这里的第一步开启时钟不需要我们写代码来执行 2.写入预分频器和重装寄存器 在写入这两个寄存器之前…

git知识

如何将develop分支合并到master分支 #简单版 git checkout master git pull origin master git merge origin/develop # 解决可能的冲突并提交 git push origin master#复杂版 git checkout master # 拉取远程 master 分支的最新代码并合并到本地 git pull origin master # 拉…

Linux:软件包管理器 - yum

Linux&#xff1a;软件包管理器 - yum Linux的软件安装方式源代码安装rpm包安装yum安装 yum三板斧yum listyum installyum remove yum生态yum源 Linux的软件安装方式 源代码安装 在Linux下安装软件, 一个通常的办法是下载到程序的源代码, 并进行编译, 得到可执行程序 源代码安…

若依ts版本(vue3+element plus+ts)

1、项目简介 本项目参考若依前后端分离版&#xff0c;前端由[若依vue3]改写为ts版本[ruoyi-web-vue3-ts]&#xff0c;后端对[若依V3.8.7]进行了修改[后端版本分支vue3.ts.3.8.7]&#xff0c;具体文档参见[若依官方文档]。本项目对部分代码做了优化&#xff0c;增加了activiti7…

LeetCode-5. 最长回文子串【字符串 动态规划】

LeetCode-5. 最长回文子串【字符串 动态规划】 题目描述&#xff1a;解题思路一&#xff1a;动态规划五部曲解题思路二&#xff1a;动态规划[版本二]解题思路三&#xff1a;0 题目描述&#xff1a; 给你一个字符串 s&#xff0c;找到 s 中最长的回文 子串 。 如果字符串的反序…

【MYSQL】索引机制概述

由于MySQL是作为存储层部署在业务系统的最后端&#xff0c;所有的业务数据最终都要入库落盘&#xff0c;但随着一个项目在线上运行的时间越来越久&#xff0c;数据库中的数据量自然会越来越多&#xff0c;而数据体积出现增长后&#xff0c;当需要从表查询一些数据时&#xff0c…

网络安全入门教程(非常详细)从零基础入门到精通

网络安全是一个庞大而不断发展的领域&#xff0c;它包含多个专业领域&#xff0c;如网络防御、网络攻击、数据加密等。介绍网络安全的基本概念、技术和工具&#xff0c;逐步深入&#xff0c;帮助您成为一名合格的网络安全从业人员。 一、网络安全基础知识 1.计算机基础知识 …

蓝桥杯省赛冲刺(3)广度优先搜索

广度优先搜索&#xff08;Breadth-First Search, BFS&#xff09;是一种在图或树等非线性数据结构中遍历节点的算法&#xff0c;它从起始节点开始&#xff0c;按层级逐步向外扩展&#xff0c;即先访问离起始节点最近的节点&#xff0c;再访问这些节点的邻居&#xff0c;然后是邻…