首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

MySQL灵魂十

应该:1、重复率小的列建议生成索引。因为重复数据少,索引树查询更有效率,等价基数越大越好。2、数据具有唯一性,建议生成唯一性索引。...B事务如果回滚,则A事务做错了 2、 不可重复读(non-repeatable read):不可重复读的重点是修改: 同样的条件, 你读取过的数据, 再次读取出来发现值不一样了,只需要锁住满足条件的记录...可重复读(MySQL默认):别人改数据的事务已经提交,我在我的事务中也不去读,以此保证重复读一致性。串行:我的事务尚未提交,别人就别想改数据。...所以可以说 MySQL的RR级别的隔离是已经实现解决了脏读,不可重复读和幻读的。...表大,用 exists 效率较高;表小,用 in 效率较高。4、查询用not in 那么内外表都进行全表扫描,没有用到索引;而not exists 的子查询依然能用到表上的索引。

97320

MySQL | 表的连接

查询每名员工的部门信息 SELECT e.empno,e.ename,d.dname FROM t_emp e JOIN t_dept d ON e.deptno=d.deptno; 表连接的分类 表连接分为两种:连接...和 外连接 连接是结果集中只保留符合连接条件的记录 外连接是不管符不符合连接条件,记录都要保留在结果集中 连接的简介 连接是最常见的一种表连接,用于查询多张关系表符合连接条件的记录。...连接的多种语法形式 SELECT ...... FROM 表1 JOIN 表2 ON 连接条件; SELECT .........e.deptno=d.deptno; SELECT e.empno,e.ename,d.dname FROM t_emp e , t_dept d WHERE e.deptno=d.deptno; 连接练习...,只要字段之间符合逻辑关系就可以 连接练习2 查询与 SCOTT 相同部门的员工都有谁?

3.3K20

MySQL冗余和重复索引

MySQL允许在相同列上创建多个索引,无论是有意还是无意,mysql需要单独维护重复的索引,并且优化器在优化查询的时候也需要逐个地进行考虑,这会影响性能。   ...重复索引是指的在相同的列上按照相同的顺序创建的相同类型的索引,应该避免这样创建重复索引,发现以后也应该立即删除。但,在相同的列上创建不同类型的索引来满足不同的查询需求是可以的。...) 怎么找出冗余索引和重复索引呢?...2.可以使用Percona Toolkit中的pt_duplicate-key-checker,该工具通过分析表结构来找出冗余和重复的索引。...参考文献:  [1] Baron Schwartz等 著,宁海元等 译 ;《高性能MySQL》(第3版); 电子工业出版社 ,2013 高性能MySQL(第3版) 中文PDF带目录清晰版 下载  http

1.4K20

MySQL | 查找删除重复

这个问题还可以有其他演变,例如,如何查找“两字段重复的行”(#mysql IRC 频道问到的问题) 如何查找重复行 第一步是定义什么样的行才是重复行。多数情况下很简单:它们某一列具有相同的值。...如何删除重复行 一个相关的问题是如何删除重复行。一个常见的任务是,重复行只保留一行,其他删除,然后你可以创建适当的索引,防止以后再有重复的行写入数据库。 同样,首先是弄清楚重复行的定义。...尤其对于MYSQL,有些限制是不能在一个查询语句中select的同时update一个表。简单起见,这里只用到了临时表的方法。 我们的任务是:删除所有重复行,除了分组中id字段具有最小值的行。...但如果是判断b字段重复或者c字段重复,问题困难得多。这里提问者用到的样本数据。...,而不是重复的字段值。

5.8K30

MySQL 的可重复

我在这里分享一篇关于 MySQL 的可重复读介绍,讲得挺好的,可以解决一些疑惑,链接在下方引用处。...但是,MySQL 的可重复读比 SQL 的可重复读的标准要更高,具体表现为:仅仅用 select 语句时幻读不会发生(这种情况简称 Phantom Reads),但是出现与写有关的操作时幻读会发生(这种情况简称...所以这就解释了某些文章会说 MySQL 的可重复读可以防止某些幻读情况的出现。...另外,从面试的角度来说,如果没有强调是 MySQL 的情况,可以忽略这些,只要按照 SQL 的关于幻读和可重复读的定义来回答即可。...引用: 一篇关于 MySQL 的可重复读介绍: https://blog.pythian.com/understanding-mysql-isolation-levels-repeatable-read

1.8K20

MySQL索引15问,抗住!

金三银四很快就要来啦,准备了索引的15问,相信大家看完肯定会有帮助的。 1. 索引是什么? 索引是一种能提高数据库查询效率的数据结构。它可以比作一本字典的目录,可以帮你快速找到对应的记录。...普通索引:MySQL中基本索引类型,允许空值和重复值。 联合索引:多个字段创建的索引,使用时遵循最左前缀原则。 唯一索引:索引列中的值必须是唯一的,但是允许为空值。...mysql 估计使用全表扫描要比使用索引快,则不使用索引。 4. 哪些场景不适合建立索引?...unique_subquery:类似于eq_ref,条件用了in子查询 index_subquery:区别于unique_subquery,用于非唯一索引,可以返回重复值。...(但是索引列的重复值很多的话,Hash冲突,效率降低)。 B+树使用 like 进行模糊查询的时候,like 后面(比如%开头)的话可以起到优化的作用,Hash 索引根本无法进行模糊查询。 14.

1.4K30

MySQL索引18问,谁能顶住

InnoDB 引擎 逻辑维度 主键索引: 主键索引是一种特殊的唯一索引,不允许值重复或者值为空。 普通索引: 普通索引是 MySQL 中最基本的索引类型,允许在定义索引的列中插入重复值和空值。...数据维度:如果索引列具有大量重复值,Hash索引的效率可能会下降,因为哈希碰撞会导致性能下降。在这种情况下,B+ 树索引可能更为稳定。...数据重复且分布平均的字短没必要建立索引(比如:性别) 索引并非银弹,正确使用才能发挥奇效。 8. 索引什么时候会失效?...具有唯一性约束的列: 对于需要保证唯一性的列,如主键或具有唯一约束的列,建立索引是必要的,因为索引可以帮助快速检查重复的数据。...分析数据分布:对于列的值分布进行分析,避免在高度重复的列上创建索引,因为这样的索引可能不会带来显著的性能提升。 避免过度索引:过多的索引会增加数据库的维护成本,尤其是在数据插入、更新和删除时。

11500
领券