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

MySQL查询的索引使用

项目中一般使用的都是单查询,但是在一些业务场景下,偶尔会选择查询,一直对联查询时如何使用索引一直感到很好奇。...正好近期项目中遇到一个问题,查询时,没有建立索引,耗时居然达到了可耻的10分钟,所以趁机了解了一下。...,根据MySQL查询的算法Nested-Loop Join,MySQL查询的结果集是3张的笛卡尔积,所以效率特别低。...比如:在knowledge的字段update上建立索引idx_time: MySQL [knowledge_base]> alter table knowledge add index idx_time...[(none)]> kill 3468722 结论 关联字段一定要添加索引 where条件的索引建立,一定要查看explain,mysql的工作方式经常跟我们想的不一样 增加慢查询日志(dba呢?)

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

    mongodb查询_mongodb聚合查询

    在使用MongoDB存储数据的时候,我们查询的时候,有时候难免会需要进行连查询。但是MongoDB本身是非关系性数据库,连查询,很多时候,需要我们自己在代码里手工操作。...其中 user 中的字段有 _id、uid、name、age;order 中的字段有:_id、uid、product、money; 两张存储的数据为: users = [{ _id: ObjectId...", // user 关联的字段 foreignField: "uid", // order 关联的字段 as: "orders" } }]); 这个时候出来的结果应该为: users...", // user 关联的字段 foreignField: "uid", // order 关联的字段 as: "orders" } }, { $unwind: { //...查询用户的订单信息 2.1 连查询 这个时候的连是 order 跟 user 关联(上一个是 user 和 order 关联) { $lookup: { from: "users

    2.8K20

    来了,MyBatisPlus的join查询

    说明: UserDTO.class 查询结果返回类(resultType) selectAll() 查询指定实体类的全部字段 select() 查询指定的字段,支持可变参数,同一个select只能查询相同字段...参与连的实体类class 第二个参数: 连的ON字段,这个属性必须是第一个参数实体类的属性 第三个参数: 参与连的ON的另一个实体类属性 默认主表别名是t,其他的别名以先后调用的顺序使用t1,t2...条件查询,可以查询主表以及参与连接的所有字段,全部调用mp原生的方法,正常使用没有sql注入风险 MPJLambdaWrapper 还有很多其他的功能 简单的SQL函数使用:https://gitee.com...策略是覆盖,以最后一次为准,这里的策略是追加,可以一直select 主表字段可以用lambda,会自动添加别名,主表别名默认是 t ,非主表字段必须带别名查询 leftJoin() rightJoin...() innerJoin() 传sql片段 格式 ( + 别名 + 关联条件) 条件查询,可以查询主表以及参与连接的所有字段,全部调用mp原生的方法,正常使用没有sql注入风险 分页查询 class

    5.6K51

    sql学习笔记(三)—— 查询

    上篇写了一些sql查询的知识,这篇接着写一下有关联查询的知识。 既然是查询,那肯定得多个啊,所以,我们先创建一个教师表,名为 teacher,并且向中插入数据。...字段5,字段6,字段7,字段8 from 2 union select 字段9,字段10,字段11,字段12 from 3 ... -- 注意点:这里的 字段1-字段4、字段5-字段8、字段...3.交叉连接 cross join 交叉连接会把左中的每一行与右中的每一行一一进行排列组合,然后全部显示出来,如果左有6条记录,右有7条记录,则查询后的结果应该有42条记录。...查询就记录到这里啦,后面会看一下多表查询,嘿嘿,加油!...最后附上我本章的sql脚本: 1 -- 查询 -- 2 select * from student 3 4 -- 新建teacher -- 5 6 drop table teacher

    1.1K10

    MyBatis_Plus分页查询

    MyBatis_Plus分页查询 当我们需要关联表格分页查询时,MyBatis_plus封装的单方法已经满足不了我们的需求了,那么我们需要进行分页查询 假设我们需要的 SQL 语句如下:...order by su.create_time desc 那么我们需要进行如下操作: 1、新建 UserInfoVO.java UserInfoVo实际上是一个页面数据对象,由于页面上需要显示用户的数据还需要根据用户去查询另一张中的角色名称...,所以UserInfoVO类似构造了一个MyBatis中的result,在MP中我们可以使用IPage来返回自定义多表联合查询列表数据并分页的展示需求。...@Excel(name = "删除状态", width = 15, dicCode = "del_flag") private Integer delFlag; //其他的数据...()时的操作,使用拼写SQL的方式实现多表联合分页查询,是效率最高的一种。

    1.1K20

    MySQL修改字段

    MySQL修改字段 MySQL 修改表字段的方法有两种: ALTER TABLE MODIFY COLUMN。...1、ALTER TABLE 方法 ALTER TABLE 方法用于修改结构,包括增加、删除和修改表字段。...其语法如下: ALTER TABLE 名 MODIFY COLUMN 字段字段类型; 其中,名 表示要修改的名,字段名 表示要修改的字段名,字段类型 表示修改后的字段类型。...例如,修改 users 的字段 username 的类型为 VARCHAR(50),可以使用以下 SQL 语句: ALTER TABLE users MODIFY COLUMN username VARCHAR...其语法如下: ALTER TABLE 名 MODIFY COLUMN 字段字段类型 [属性]; 其中,名 表示要修改的名,字段名 表示要修改的字段名,字段类型 表示修改后的字段类型,属性 表示修改后的字段属性

    5.4K10

    MySQL查询

    是一种数据库分割技术,用于将大拆分成多个小,以提高数据库的性能和可管理性。在MySQL中,可以使用多种方法进行分,例如基于范围、哈希或列表等。...下面将详细介绍MySQL如何分以及分后如何进行数据查询。 基于哈希的分 基于哈希的分是一种将数据分散到多个子表中的数据库分策略。这种方法通过计算数据的哈希值来决定数据应该存储在哪个子表中。...基于哈希的分可以帮助平均分布数据,提高查询性能,并减轻单个的负载。下面是详细介绍如何基于哈希的分的步骤: 步骤1:创建子表 首先,你需要创建多个子表,每个子表将存储一部分数据。...示例插入数据: -- 计算数据的哈希值(示例使用MySQL的MD5哈希函数) SET @hash = MD5(CONCAT(customer_id, order_date)); -- 根据哈希值决定插入到哪个子表中...•查询路由算法: 查询路由算法应该与数据分布策略一致,以确保正确路由查询。 基于列表的分 基于列表的分是一种数据库分策略,它根据某个列的值将数据分割到不同的子表中。

    84620

    MySQL查询

    查询的语法及关键字执行的优先级 单查询语法 SELECT DISTINCT 字段1,字段2......1.找到:from 2.拿着where指定的约束条件,去文件/中取出一条条记录 3.将取出的一条条记录进行分组group by,如果没有group by,则整体作为一组 4.执行select(去重)...单独使用GROUP BY关键字分组 SELECT post FROM employee GROUP BY post; 注意:我们按照post字段分组,那么select查询字段只能是post...强调: 如果我们用unique的字段作为分组的依据,则每一条记录自成一组,这种分组没有意义 多条记录之间的某个字段值相同,该字段通常用来作为分组的依据 聚合函数 ?...SELECT * FROM employee ORDER BY salary ASC; SELECT * FROM employee ORDER BY salary DESC; 按列排序

    17.8K10

    MySQL查询某个中的所有字段并通过逗号分隔连接

    造一些测试数据,字段又多一个个敲很麻烦,导出中部分字段数据又不想导出ID字段(因为ID字段是自增的,导出后再插入会报唯一性错误),select * 查出来又是所有的字段。...可以通过如下SQL查询中所有字段通过逗号连接,然后复制出来进行select查询再导出 select group_concat(COLUMN_NAME) '所有字段' from information_schema.COLUMNS...where table_name = '名'; 执行效果如下: 下面的语句可以查询某个库中某个的所有字段字段的名称、类型、字符长度和字段注释等信息 select * from information_schema.COLUMNS...where table_name = '名' and table_schema = '数据库名'; 执行效果如下:

    9.4K20

    MySQL之单查询、多表查询

    一、单查询: 单个查询方法及语法顺序需要通过实际例子来熟悉 先将数据创建下: ? ?...查询数据的条件依据 找到数据形成虚拟 ②、where约束条件的使用 # 1.查询id大于等于3小于等于6的数据 mysql> select * from emp where id >=...多个之间的查询一般都是在 之间存在某种逻辑关联的情况下进行的查询,这种逻辑上的关联其实就是中某个字段名和另外一个中的字段名存在一个一一对应的关系或者关联。...t2 # (select post,max(hire_date) as max_date from emp group by post) as t2 # ②为了易读性,将emp起名为t1,将需要查询的结果字段名写在...,也可以通过其别名的方式把它作为一张虚拟去跟其他做关联查询 额外题: 部门中薪资超过部门平均薪资的员工姓名及薪资 mysql> select t1.name,t1.salary,t1.post,t2

    22K30

    Mysql千万级大添加字段

    MySQL数据添加新字段 有时候我们在测试环境给一个添加字段,但是在线上环境添加一个字段,却极其的慢。...执行加字段操作就会锁,这个过程可能需要很长时间甚至导致服务崩溃。...,导致新数据流失不完整 总结 生产环境MySQL添加或修改字段主要通过如下四种方式进行,实际使用中还有很多注意事项 直接添加 如果该读写不频繁,数据量较小(通常1G以内或百万以内),直接添加即可(可以了解一下...online ddl的知识) 使用pt_osc添加 如果较大 但是读写不是太大,且想尽量不影响原的读写,可以用percona tools进行添加,相当于新建一张添加了字段的新,再将原的数据复制到新中...,切换后再将其他几个节点上添加字段 将现有MySQL版本5.7升级到8.0.12之后的版本 相关文章 Mysql事务 Mysql中的索引 Mysql通过binlog恢复数据

    10.4K30

    谈一谈Mybatis-plus的查询

    在学习完Mybaits-plus之后,发现相比于Mybatis确实便捷了很多,但是本我在学习的时候就在想单这么简单,能自动生成SQL!...然后想多表查询呢,于是网上各种各样查资料,有关于Mybatis-plus查询的资料并不多包括官网!...查询肯定会涉及到动态SQL,具我查看到的资料,我想每种方式点评一下: 1、QueryWrapper  用它去做可谓是复杂呀,字段,条件一自己都看不过来!更不说找错,维护了。...不过它配合MybatisPlus单自动生成SQL的方法去完成一些简单的条件查询还是不错的 2、XML 从Mybatis学过来的肯定都知道它,本人认为它是非常棒的,不用再学习QueryWrapper这样的编程式...后期找错,维护SQL也是一目了然 3、注解 在学习Mybaits时经常用它来实现简单的单操作,但是现在MybatisPlus提供了单自动生成SQL。用注解去写、动态SQL那也可是相当麻烦!

    24820
    领券