首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

为什么MySQL不推荐使用子查询和join

来源:cnblogs.com/liboware/p/12740901.html 1.对于mysql,不推荐使用子查询和join是因为本身join的效率就是硬伤,一旦数据量很大效率就很难保证,强烈推荐分别根据索引单表取数据...三、不推荐使用join的原因 1.DB承担的业务压力大,能减少负担就减少。...当表处于百万级别后,join导致性能下降; 2.分布式的分库分表。这种时候是不建议跨库join的。目前mysql的分布式中间件,跨库join表现不良。...五、join查询的优势 关联查询的好处是可以做分页,可以用副表的字段做查询条件,在查询的时候,将副表匹配到的字段作为结果集,用主表去in它。...但是问题来了,如果匹配到的数据量太大就不行了,也会导致返回的分页记录跟实际的不一样,解决的方法可以交给前端,一次性查询,让前端分批显示就可以了,这种解决方案的前提是数据量不太,因为sql本身长度有限。

4.2K30

为什么分库分表后不建议跨分片查询

来源:阿飞的博客 在这篇文章中提到了一个场景,即电商的订单。我们都知道订单表有三大主要查询:基于订单ID查询,基于商户编号查询,基于用户ID查询。...且那篇文章给出的方案是基于订单ID、商户编号、用户ID都有一份分库分表的数据。那么为什么要这么做?能否只基于某一列例如用户ID分库分表,答案肯定是不能。...; ---- 为什么慢 我们要弄明白跨分片查询为什么这么慢之前,首先要掌握跨分片查询原理。...需要说明的是,当路由结果只有1个,即不跨分片操作时sharding-sphere不会通过线程池异步执行,而是直接同步执行,这么做的原因是为了减少线程开销,核心源码在ShardingExecuteEngine.java...既然是这个执行原理,为什么跨分片查询,随着跨分片数量越多,性能会越来越差?我们再看一下第2个测试场景,当测试跨1个分表时,1w次查询只需要5889ms,即平均1次查询不到1ms。

1.8K30
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    nc命令卡住不返回的分析

    具体通过如下命令获取zk的状态: echo stat | nc 192.168.73.77 2181 出现问题时,发现nc命令一直没有返回,导致无法执行后续的步骤(程序压根没启动)。...不信邪,再多试几次,nc命令均正确返回退出,并且能获取到对应的状态信息,看来是个偶现问题。 既然命令当前执行都正常,难道是执行nc命令的那个时刻,zk出现了异常导致没有响应?...而长度为0的可读事件,是收到FIN后,内核协议栈往上发送的可读事件。 结合上面说的FIN_WAIT2,就可以知道nc命令为什么不退出了。...通过增加参数“+vvvvvv”查看nc命令执行过程中的输出,对比正常情况和异常情况,可以清楚的看到这一点: 正常退出的情况: 异常不退出的情况: 清楚了问题的所有环节,只剩下为什么nc命令没有收到...简单man了一把nc,发现有一个"-i"参数,指的是连接的最大读写空闲时间。加上参数,再来进行测试,发现连接虽然处于FIN_WAIT2状态,但等待指定时长后,nc命令返回退出了。

    2.7K30

    从根上理解SQL的like查询%在前为什么不走索引?

    我再次的阐述一下,用索引和走索引不是一个意思! 其实每天都有人私信我,如果遇到一些好的问题,我会拿来单独写文章的。比如,昨天就有人问我,like 查询 % 在前为什么不走索引?...不能人云亦云,我们应该从根上理解它,为什么要这样设计?为什么不走索引? 其实结果对我来说,并不重要,重要的是过程。设计过程或者实现过程,这才是我最关心的。...所以,今天我就从根上给你说一说为什么 like 查询 % 在前为什么不走索引? 例如,看这个例子: ? 说到这个例子,估计很多人会提到最左匹配原则。那么为什么要搞一个最左匹配原则呢?...为什么不搞一个最右匹配原则? 这个问题,其实是和 B+Tree 有些关系,索引树从左到右都是有顺序的。对于索引中的关键字进行对比的时候,一定是从左往右以此对比,且不可跳过。 为什么是最左匹配原则?...后面,我再给你们讲讲,为什么说索引的离散型越高越好!

    5.2K20

    面试官:为什么mysql不建议执行超过3表以上的多表关联查询?

    点关注,不迷路;持续更新Java架构相关技术及资讯热文!!!...tag_id=1234; Select * from post where id in(123,456,567,9989,8909); 为什么会这样做呢?...原本一条查询,这里却变成了多条查询,返回结果又是一模一样。 事实上,用分解关联查询的方式重构查询具有如下优势: 让缓存的效率更高。 许多应用程序可以方便地缓存单表查询对应的结果对象。...另外对于MySQL的查询缓存来说,如果关联中的某个表发生了变化,那么就无法使用查询缓存了,而拆分后,如果某个表很少改变,那么基于该表的查询就可以重复利用查询缓存结果了。...将查询分解后,执行单个查询可以减少锁的竞争。 在应用层做关联,可以更容易对数据库进行拆分,更容易做到高性能和可扩展。 查询本身效率也可能会有所提升 可以减少冗余记录的查询。

    8.6K00

    为什么不试试神奇的3407呢?

    他提出以下问题:随机种子的不同导致的模型效果分布是怎样的?是否有黑天鹅,即产生截然不同结果的种子?对较大数据集进行预训练是否可以减少由选择种子引起的差异性?...因此,第一个问题的答案为:随机种子的不同导致的模型效果分布是类似正态集中的。...得到结果如下: 作者得出:大数据集的上的结果标准差是比CIFA 10小得多的,根据上表还是能够观察到大约0.5%的结果提升——这仅仅是由于随机种子引起的。...然而,0.5%的准确率提高在CV领域已经可以算是很明显的提升了。第三个问题的答案是复杂的:在某种意义上,是的,使用预处理模型和较大的训练集可以减少种子选择引起的变化。...如果种子设定为相同的,那么得到的初始权重就是一样的。

    39020

    为什么getTime()返回1970年至今的毫秒?

    今天在写new Date()时候,无意中发现了一个很有意思的方法,getTime(),百度了一下,有人说是计算从1970年1月1日至今的毫秒数 为什么要是1970年呢?...为什么这个时间会定义在1970年1月1日这个时候呢? 于是开始了Google,中文网页根本找不到答案。...于是试着搜索英文关键字,在Sun java论坛总算找到准确的帖子: http://forums.sun.com/thread.jspa?...但这依然没很好的解释"为什么",出于好奇,继续Google,总算找到了答案: http://en.wikipedia.org/wiki/Unix_time 这里的解释是: 最初计算机操作系统是32位,而时间也是用...到这里,我想问题的答案已经出来了: 因为用32位来表示时间的最大间隔是68年,而最早出现的UNIX操作系统考虑到计算机产生的年代和应用的时限综合取了1970年1月1日作为UNIX TIME的纪元时间(开始时间

    1.2K30

    Mybatis查询结果为空时,为什么返回值为NULL或空集合?

    目录 背景 JDBC 中的 ResultSet 简介 简单映射 回归最初的问题:查询结果为空时的返回值 结论 背景 一行数据记录如何映射成一个 Java 对象,这种映射机制是 MyBatis 作为 ORM...开始前我们先看一个问题: 你是否曾经在学习 Mybatis 的时候跟我有一样的疑问,什么情况下返回 null,什么时候是空集合,为什么会是这种结果?那么你觉得上述这种回答能说服你嘛?...看完这篇你就知道查询结果为空时候为什么集合会是空集合而不是 NULL,而对象为什么会是 NULL 了。 PS:对过程不感兴趣的可以直接跳到最后看结论。...handleRowValuesForSimpleResultMap() 方法处理不包含嵌套映射的简单 ResultMap。...回归最初的问题:查询结果为空时的返回值 | 返回结果为单行数据 可以从 ResultSetHandler的handleResultSets 方法开始分析。

    5.4K20

    Go: 命名返回值的使用, return携带还是不携带?

    在Go语言中,命名返回值提供了一种声明函数返回值的方式,它可以增加代码的可读性和灵活性。但是,在使用命名返回值时,return语句是否应该明确携带返回值,是一个常见的困惑。...带命名返回值的return 如果在函数中使用了命名返回值,你可以在return语句中明确指定返回的值,如下所示: func sum(a, b int) (result int) { result =...不带命名返回值的return 或者,你可以省略return语句中的返回值,让Go自动返回命名返回值的当前值: func sum(a, b int) (result int) { result = a...建议做法 对于简单的函数,可以考虑省略return语句中的返回值,使代码更精简。 对于复杂的函数或重要的库,可能更适合明确指定返回值,以增加代码的可读性和可维护性。...总结 命名返回值在Go语言中是一个强大的工具,但如何使用它没有固定的规则。选择是否在return语句中携带返回值取决于多个因素,包括代码的复杂性、团队的编程风格以及可读性和可维护性的需求。

    48930

    查询网站所有的子域名的方法 为什么要查询

    提及域名查询应该很多人都不陌生了,即便没有操作过也是听说过的,其含义通常指的是查询WHOIS的注册信息。...大家平时上网都是需要使用域名的,而其中有不少的用户都想要了解更多的关于域名和服务器信息,此时可能还会涉及到查询网站所有的子域名的操作。...image.png 如何进行域名查询 查询网站所有的子域名听起来有点复杂,但其实并不是特别难的事情,因为现如今已经有一些网站和工具可以提供此项服务了。...一般来说查询子域名的工具或网站要按照以下标准来选,分别是查询的准确率,是否能够查看到具体的注册信息,是否可以查到与该域名相似的域名推荐,快捷和没有验证码等。...再者如果想要得知注册者、注册和到期的日期等信息,也可以通过查询获得。 以上就是关于查询网站所有的子域名的相关介绍,可见查询的途径绝非一种,但是否好用就见仁见智了,适合自己的才是最好的方式。

    6.2K20

    为什么 useState 返回的是 array 而不是 object?

    [count, setCount] = useState(0) 这里可以看到 useState 返回的是一个数组,那么为什么是返回数组而不是返回对象呢?...为什么是返回数组而不是返回对象 要弄懂这个问题要先明白 ES6 的解构赋值,来看 2 个简单的例子: 数组的解构赋值 const foo = [1, 2, 3]; const [one, two, three...,这个问题就很好解释了 如果 useState 返回的是数组,那么使用者可以对数组中的元素命名,代码看起来也比较干净 如果 useState 返回的是对象,在解构对象的时候必须要和 useState 内部实现返回的对象同名...总结 useState 返回的是 array 而不是 object 的原因就是为了降低使用的复杂度,返回数组的话可以直接根据顺序解构,而返回对象的话要想使用多次就得定义别名了 首发自:为什么 useState...返回的是 array 而不是 object?

    2.3K20

    扒一扒知乎上的帖子——“为什么有些大公司技术弱爆了?”

    我刚看到标题的时候,先入为主和刻板偏见了一下,正如同第一个回答一样,我皱了皱眉头,产生了对题主的鄙视之情;但是很快,读完帖子以后,我却立场明确地站到题主一边了。...代码写的一团糟,全是复制粘贴,连作者都没改,大家普遍不写注释,也不格式化,代码歪歪扭扭。 >> 这又是一件不该发生的事情。...对于代码质量的追求各有说法,但是 “复制粘贴”、“作者都没改”、“不写注释”、“不格式化” 等等这样的字眼,我不相信一般的 “龙头” 公司能够接受。...这样的低级问题都出现……难道代码不用 review 么? 该公司混了两年的程序员,跟快递公司做查询接口,竟然不知道加密运单号。...>> 如果只是牵涉到服务之间的通讯,而通讯又只是简单的查询的话,没有 requestId 我觉得是可以接受的。

    37910

    BI为什么我的查询运行多次?

    此行为是正常的,旨在以这种方式工作。引用单个数据源的多个查询如果多个查询从该数据源拉取,则可能会出现对同一数据源的多个请求。 即使只有一个查询引用数据源,这些请求也会发生。...如果查询由一个或多个其他查询引用,则独立计算每个查询(以及它依赖的所有查询)。在桌面环境中,使用单个共享缓存运行数据模型中所有表的单个刷新。...在云环境中,每个查询都使用自己的单独缓存进行刷新,因此查询无法受益于已为其他查询缓存的相同请求。折叠有时,Power Query的折叠层可能会根据正在下游执行的操作生成对数据源的多个请求。...隔离多个查询可以通过关闭查询过程的特定部分来隔离多个查询的实例,以隔离来自重复请求的位置。...此步骤假设你不担心源之间的数据泄漏,因此,可以使用Excel中的“设置快速组合”选项中所述的“始终忽略隐私级别”设置设置来完成数据隐私防火墙的禁用,或者使用“忽略隐私级别”,并可能会提高Power BI

    5.5K10
    领券