当数据库需要处理操作量大、复杂度高的数据的时候需62616964757a686964616fe78988e69d8331333431363633要用到事务。用事务是为了保证数据库的完整性,保证成批的 SQL 语句要么全部执行,要么全部不执行。一个数据库事务通常包含了一个序列的对数据库的读/写操作。它的存在包含有以下两个目的:1、为数据库操作序列提供了一个从失败中恢复到正常状态的方法,同时提供了数据
转载
2023-08-07 21:18:33
127阅读
事务具有以下属性:1. 原子性:一个事务要被完全性的无二义性的做完或者撤销,在任何一个操作出现错误的情况下,构成事务所有操作所造成的效果都必须被撤销,数据应该被回滚到以前的状态。2. 一致性:一个事务应该保护所有定义在数据上的不变的属性(例如完整性约束)。在完成了一个成功的事务时,数据应处于一致的状态。换句话说,一个事务应该把系统从一个一致-状态转换到另一个一致状态。举个例子,在关系数据库的情况下
转载
2023-10-10 10:08:45
55阅读
写在前面网上看帖子的时候,经常会看到说尽量用exists,少用in。那么问题来了,是所有场景下都尽量用exists吗,还是具体场景具体分析。给你答案mysql做子查询的时候,永远记得要小表驱动大表。inselect * from A where id in (select id from B);相当于先循环B,再循环A。B表驱动A表。也就是当B表数据少于A表时,用in最佳。existsselect * from A whereexists(select 1 ...
原创
2021-12-29 16:09:09
324阅读
in后面跟的是小表,exists后面跟的是大表。
简记:in小,exists大。
对于exists
select .....from table where exists(subquery);
可以理解为:将主查询的数据放入子查询中做条件验证,根据验证结果(true或false)来决定主查询的数据是否得以保留。
转载
2024-04-03 15:45:00
0阅读
事务主要用于处理操作量大,复杂度高的数据。 比如说,在人员管理系统中,你删除一个人员,你即需要删除人员的基本资料,也要删除和该人员相关的信息,如信箱,文章等等,这样,这些数据库操作语句就构成一个事务!1、在 MySQL 中只有使用了 Innodb 数据库引擎的数据库或表才支持事务。 2、事务处理可以用来维护数据库的完整性,保证成批的 SQL 语句要么全部执行,要么全部不执行。 3、事务用来管理 i
转载
2024-05-29 06:17:00
19阅读
路漫漫其修远兮,吾将上线而求索。《深入浅出MySql》学习笔记-选择合适的数据类型一、CHAR与VARCHARCHAR:固定长度,处理速度相对较快,但是会删除数据尾部的空格。适用于对长度变化不大并且对查询速度有较高要求的数据。VARCHAR:可变长度。注:MyISAM:建议使用固定长度的数据列代替可变长度的数据列。MEMORY:目前都是都是使用固定长度的数据行存储,因此无论使用CHAR或者VARC
转载
2024-04-11 11:19:27
91阅读
按照五点把书中的内容进行一下整理:1、为什么要选择Redis:介绍Redis的使用场景与使用Redis的原因;2、Redis常用命令总结:包括时间复杂度总结与具体数据类型在Redis内部使用的数据结构;3、Redis的高级功能:包括持久化、复制、哨兵、集群介绍;4、理解Redis:理解内存、阻塞,这部分是非常重要的,前面介绍的都可以成为术,这里应该属于道的部分;5、开发技巧:主要是一些开发实战的总
转载
2023-08-08 21:24:01
312阅读
不同的引擎对于索引有不同的支持:Innodb和MyISAM默认的索引是Btree索引;而Mermory默认的索引是Hash索引。我们在mysql中常用两种索引算法BTree和Hash,两种算法检索方式不一样,对查询的作用也不一样。 区别:哈希索引适合等值查询,但是无法进行范围查询
哈希索引没办法利用索引完成排序
哈希索引不支持多列联合索引
转载
2023-08-05 00:56:58
246阅读
在服务器的硬件或软件发生问题时,可以不用管数据库发生了什么,不需要执行任何操作就可以直接重启。InnoDb的crash recovery机制会自动的完成在发生故障前的数据变更提交,不会恢复任何已经发生改变但是没有提交的数据。InnoDB有它自己的buffer pool去缓存表和索引数据在主存中便于访问。频繁被访问的数据会从内存中直接获取到。缓存可以被用于很多类型的信息并且能提高处理速度。在专门用于
1、较频繁地作为查询条件的字段这个都知道。什么是教频繁呢?分析你执行的所有SQL语句。最好将他们一个个都列出来。然后分析,发现其中有些字段在大部分的SQL语句查询时候都会用到,那么就果断为他建立索引。2、唯一性太差的字段不适合建立索引什么是唯一性太差的字段。如状态字段、类型字段。那些只存储固定几个值的字段,例如用户登录状态、消息的status等。这个涉及到了索引扫描的特性。例如:通过索引查找键值为
转载
2023-10-09 20:41:26
115阅读
# MySQL 事务何时完成:初学者指南
在数据库的操作过程中,事务是一个非常重要的概念。事务处理保证了多个操作要么全部成功,要么全部失败。这样可以确保数据库的完整性和一致性。在这篇文章中,我将引导你了解MySQL事务的整个流程,并通过代码示例帮助你实现事务管理。
## 事务操作流程
以下是实现MySQL事务的基本步骤:
| 步骤 | 描述
MySQL事务是数据库操作的重要组成部分,在MySQL数据库中,事务会在特定条件下自动上锁,这里会逐步带你了解MySQL事务的锁定机制,以及如何进行高效的备份、恢复、监控和迁移。
### 备份策略
首先,你需要制定有效的备份策略,以确保你的数据能够在突发情况下迅速恢复。这其中包括定期备份和使用适当的存储介质。我们可以使用甘特图来展示备份计划中的时间安排。
```mermaid
gantt
事务的引入提到事务,我们肯定会不陌生,在和数据库打交道的时候,我们通常会用到事务。最经典的例子就是转账,你要给朋友小王转100块钱,但是你此时银行卡上只有100块。转账的过程具体到程序中就会有一系列的操作,比如查询余额,做加减法,更新余额等,这些操作必须保证是一体的,不然等程序查完之后,还没有做加减法之前,你这100块钱,完全可以借助时间差再查一次,然后再给另一个朋友转账,如果银行这么整,不久全乱
转载
2023-12-25 11:03:12
44阅读
文章目录Mysql性能优化 - innodb的事务和锁事务什么是事务事务ACID特性事务并发会产生的问题事务的四种隔离级别锁innodb 锁类型 Mysql性能优化 - innodb的事务和锁事务什么是事务事务数据库中的最小操作单元,是一组不可再分割的操作集合mysql中开启事务begin/start transaction -》 commit/ rollback 手动启动事务提交或者回滚set
转载
2024-06-22 09:30:48
74阅读
子查询一般用于跨表查询,习惯上,外层的查询称为父查询,圆括号中嵌入的查询称为子查询。SQL语句执行时先执行子查询部分,求出子查询部分的值,再执行整个父查询,返回最后的结果。
转载
2023-06-19 15:26:55
324阅读
GC的基础知识1.什么是垃圾C语言申请内存:malloc freeC++: new deletec/C++ 手动回收内存Java: new ?自动内存回收,编程上简单,系统不容易出错,手动释放内存,容易出两种类型的问题:忘记回收多次回收没有任何引用指向的一个对象或者多个对象(循环引用)2.如何定位垃圾引用计数(ReferenceCount)根可达算法(RootSearching)3.常见的垃圾回收
转载
2024-08-28 16:33:56
84阅读
# 什么时候使用 MySQL?
作为一名初入开发行业的小白,你可能会好奇如何在项目中合理使用 MySQL 数据库。MySQL 是一种流行的关系型数据库管理系统(RDBMS),适用于多种应用场景。在这篇文章中,我将引导你了解何时使用 MySQL 并介绍如何在实际项目中实现,从而帮助你打下扎实的基础。
## MySQL 使用流程概述
在决定使用 MySQL 数据库之前,你需要经历以下几个步骤:
一,什么情况下使用索引1. 表的主关键字自动建立唯一索引2. 表的字段唯一约束ORACLE利用索引来保证数据的完整性3. 直接条件查询的字段在SQL中用于条件约束的字段如zl_yhjbqk(用户基本情况)中的qc_bh(区册编号)select * from zl_yhjbqk where qc_bh=’7001’;4. 查询中与其它表关联的字段字段常常建立了外键关系如zl_ydcf(用电成份)中的
转载
2023-08-10 15:08:25
81阅读
前言在我们使用锁的时候,有一个问题是需要注意和避免的,我们知道,排它锁有互斥的特性。一个事务或者说一个线程持有锁的时候,会阻止其他的线程获取锁,这个时候会造成阻塞等待,如果循环等待,会有可能造成死锁。 这个问题我们需要从几个方面来分析,一是锁为什么不释放,第二是被阻塞了怎么办,第三是死锁是怎么发生的,怎么避免。死锁1. 锁的释放与阻塞锁什么时候释放? 事务结束(commit, rollback);
转载
2023-10-02 08:57:49
215阅读
索引为什么能提高数据访问性能? 很多人只知道索引能够提高数据库的性能,但并不是特别了解其原理,其实我们可以用一个生活中的示例来理解。 我们让一位不太懂计算机的朋友去图书馆确认一本叫做《MySQL性能调优与架构设计》的书是否在藏,这样对他说:“请帮我借一本计算机类的数据库书籍,是属于 MySQL 数据库范畴的,叫做《MySQL性能调优与架构设计》”。朋友会根据所属类别,前往存放“计算机”书籍区域
转载
2023-08-28 18:41:07
78阅读