; # 查询表在哪个数据库与注释 SELECT TABLE_SCHEMA, TABLE_NAME, TABLE_COMMENT FROM information_schema.TABLES WHERE...1=1 # AND TABLE_SCHEMA = '数据库名' AND TABLE_NAME = '表名' # AND TABLE_COMMENT = '表注释' ; # 查询列在哪个表与注释 SELECT...AND TABLE_SCHEMA = '数据库名' # AND TABLE_NAME = '表名' AND c.COLUMN_NAME = '列名' # AND c.COLUMN_COMMENT = '列注释...' ; # 查询所有列名与注释并用逗号分隔 SELECT TABLE_SCHEMA, TABLE_NAME, group_concat(COLUMN_NAME SEPARATOR ', ')
序 本文主要展示如何使用mysql的多列组合查询 何为多列组合查询呢,就是查询的值不再是单个列的值,而是组合列的值。...-+ | 3 | c | 30 | | 6 | e | 60 | +----+------+-------+ 2 rows in set Time: 0.119s 小结 多列组合查询平常比较少见...,初次看还觉得挺神奇的。...doc • mysql-filtering-by-multiple-columns[1] • selecting-where-two-columns-are-in-a-set[2] 外部链接 [1]...mysql-filtering-by-multiple-columns https://www.tutorialspoint.com/mysql-filtering-by-multiple-columns
序 本文主要展示如何使用mysql的多列组合查询 何为多列组合查询呢,就是查询的值不再是单个列的值,而是组合列的值。...查询 select * from t_demo where (name,score) in (('c',30),('e',60)); +----+------+-------+ | id | name...-+ | 3 | c | 30 | | 6 | e | 60 | +----+------+-------+ 2 rows in set Time: 0.119s 小结 多列组合查询平常比较少见...,初次看还觉得挺神奇的。...doc mysql-filtering-by-multiple-columns selecting-where-two-columns-are-in-a-set
MySQL Timestamp列按照日期格式查询 假如UpdateTime列的值是: 2020-12-17 13:51:08 MySQL: SELECT * FROM Test WHERE DATE(UpdateTime
1、查看mysql的慢查询日志是否开启 show variables like ‘%query%’; 可以看到slow_query_log的值是OFF,也就是mysql默认是不启用慢查询日志的。...log_queries_not_using_indexes,如果设置为ON,则会将所有没有使用索引的查询都记录为慢查询。 2、如何启用慢查询日志呢?...3、指定日志的输出格式 MySQL支持TABLE和FILE两种输出格式,可以用下面的命令来查看当前的输出格式: show variables like ‘%log_output%’; 设置输出格式: set...10秒,那么下面这个查询就一定会超时。...select sleep(11); 查看TABLE记录的慢日志: select * from mysql.slow_log; 这里面记录了查询时间、发起查询的客户端、扫描行数、执行的sql语句等信息
在正常应用场景中,常常会从HIVE中直接获取某个DATAFRAME,这个dataframe除了与数据表中某些字段的提取,还往往会涉及到一些常量列的添加,用以如区分数据等场景。...hive中原生提供了这样的功能。非常简单。 如这个语句:select *, 1 a, 24 hours from **. 就实现了在某个表的原有字列后面添加a, hours两个字段。...且这两个字段的数值都为常量。 效果如下:
在这篇博客中,我们将看看如何使用MySQL 5.7的虚拟列来提高查询性能。...说明 大约两年前,我发表了一个在MySQL5.7版本上关于虚拟列的文章。从那时开始,它成为MySQL5.7发行版当中,我最喜欢的一个功能点。...我要告诉你一些技巧,可以潜在地解决那些使用了GROUP BY 和 ORDER BY而慢的报表查询。...在这种情况下,我们有许多处理方法: 创建时间戳列和GROUP BY列的联合索引; 创建一个覆盖索引(包含所有查询字段); 仅对GROUP BY列创建索引; 创建索引松散索引扫描。...结论 MySQL 5.7的生成列提供一个有价值的方法来提高查询性能。如果你有一个有趣的案例,请在评论中分享。
-5-7-to-increase-query-performance/ 原文作者:Alexander Rubin 在这篇博客中,我们将看看如何使用MySQL 5.7的虚拟列来提高查询性能。...说明 大约两年前,我发表了一个在MySQL5.7版本上关于虚拟列的文章。从那时开始,它成为MySQL5.7发行版当中,我最喜欢的一个功能点。...我要告诉你一些技巧,可以潜在地解决那些使用了GROUP BY 和 ORDER BY而慢的报表查询。...在这种情况下,我们有许多处理方法: 创建时间戳列和GROUP BY列的联合索引; 创建一个覆盖索引(包含所有查询字段); 仅对GROUP BY列创建索引; 创建索引松散索引扫描。...结论 MySQL 5.7的生成列提供一个有价值的方法来提高查询性能。如果你有一个有趣的案例,请在评论中分享。
2021-01-13:很多列的数据,任意一列组合查询,mysql能做到,但是上亿的数据量做不到了,查的时候非常慢。我们需要一个引擎来支持它。这个引擎你有了解过吗?...问题中说的任意一列组合查询,针对上亿的数据量,最好采用基于列存储的 OLAP 场景业务的解决方案。...但是 MySQL 原生是不支持列存储引擎的,因为 MySQL 的各种接口抽象以及优化器基本都是基于行存储设计的,用列存储思路实现存储引擎会很别扭,一般不会这么做。...*** 2021-01-13:很多列的数据,任意一列组合查询,mysql能做到,但是上亿的数...如何回答呢?...2021-01-13:很多列的数据,任意一列组合查询,mysql能做到,但是上亿的数据量做不到了,查的时候非常慢。我们需要一个引擎来支持它。这个引擎你有了解过吗? 评论
一、前言 1,有人问我,count查询为啥有时候快有时候慢 2,首先要明白count查询的真正作用 2-1:统计某个列的数量 2-1:统计行数 二、原理 1,统计列时,会查询这个列不为空的数量,它是需要计算的...2,统计行数时,如果不加where,它可以直接取到结果,因为它可以利用存储引擎的特性直接获得这个值,比如count(*) 3,统计列时,如果知道这个列不能为空,会转化为count(*),从而加快速度...所以:你要知道自己要干什么,该怎么样去用 拓展:为啥慢?...在无可用的二级索引情况下,执行count会使MySQL扫描全表数据,当数据中存在大字段或字段较多时候,其效率非常低下(每个页只能包含较少的数据条数,需要访问的物理页较多) 三、实际应用 1,50万条数据...存储页的原理) 假设每页数据耗损不存满,50% 50万条数据,需要500000/1365*2 为 732个物理页 大小为16k*732为11.4M mysql空间按区分配,一区1M,假设连续的话,需要连续读
-- 注释 SELECT t.TABLE_NAME, t.COMMENTS, c.COLUMN_NAME, c.COMMENTS FROM USER_COL_C...
昨天讲到了索引的基础知识,没看的小伙伴记得看: 《爱上面试官》系列-数据库索引 MySQL 的索引长什么样子?索引到底是怎么加速查询的?...这个 MySQL 无论如何都会建起来,并且存储有完整行数据的索引,就叫聚簇索引(clustered index)。 2、二级索引 聚簇索引只能帮你加快主键查询,但是如果你想根据姓名查询呢?...你会发现这棵树的叶子节点,只有姓名和主键ID两个字段,没有行的完整数据,这时候你执行: select * from student where name = "David"; MySQL 到你刚刚创建的这棵...B+树 查询,快速查到有两条姓名是“David”的记录,并且拿到它们的主键,分别是 4 和 5,但是你要的是select *呀,怎么办?...这个不带行数据完整信息的索引,就叫二级索引(secondary index),也叫辅助索引。 3、复合索引 继续,如果我还想根据姓名和年龄同时查询呢?
MySQL 添加列,修改列,删除列 示例:ALTER TABLE tb_financial MODIFY CREATE_TIME DATETIME(3) DEFAULT NULL COMMENT '录入时间...'; ALTER TABLE:添加,修改,删除表的列,约束等表的定义。...); 删除列:alter table 表名 drop column 列名; 修改列名MySQL: alter table bbb change nnnnn hh int; 修改列名SQLServer...tb_money_withdraw MODIFY COLUMN PROGRESS VARCHAR(10) COMMENT '提现进度:0 提现申请 1审核通过 2 审核不通过 3提现成功 4 提现失败'; --注意:字段名和字段类型照写就行...---- MySQL 查看约束,添加约束,删除约束 添加列,修改列,删除列 查看表的字段信息:desc 表名; 查看表的所有信息:show create table 表名; 添加主键约束:
注释的添加 注释的添加是通过在定义表或列的时候在末尾加上 COMMENT 关键字来实现的,最长支持 1024 个字符。 可以在创建表的时候为表和列添加相应的注释。...'表的注释'; 执行上面的语句后创建了一个名为 test_comment 的表,并且为表和其中的 col1 列指定了相应的注释。...----------+ 1 row in set (0.00 sec) 注释的更新 对已经存在的表和列,可通过相应的更新修改操作来添加注释。...列注释的添加,更新 CHANGE 和 MODIFY 等效,区别在于 CHANGE 重写定义列,需要书写完整的列定义,包括新的列名称,即使你并不想修改列的免,而 MODIFY 则不用指定新的列名称。...' 1 row in set (0.00 sec) 表注释的添加,更新 通过 ALTER TABLE 来完成对表注释的添加和更新。
虽然知道了是什么,也知道了为什么,但是我也一直好奇底层是怎么实现的,所以今天我们来扒一扒它的庐山真面目。 1....offset 和 limit 的值都不能为负数,在源码里这两个属性定义的是无符号整数,并且在解析阶段就做了限制,如果为负数,直接报语法错误了。 2....所以,在这一步要判断已发送记录数量(send_records)和需要发送记的录数量(select_limit_cnt)之间的关系,如果已发送记录数量大于等于需要发送的记录数量,则结束查询,否则就接着进入第...不过这种方案也有个问题,不支持跳着翻页,只支持顺序翻页(就是每次都点下一页的这种)。 如果要支持跳着翻页,怎么办?...ID,然后用这些主键 ID 去 MySQL 中查询对应的数据,从而用两把锤子间接的实现了分页功能。
今天没有学员提问 只有同事点名 怎么一键取消隐藏的行和列 假设一个表是这样的 我们看到不连续的字母和数字 就知道它有隐藏行列了 如何快速取消隐藏呢 直接上GIF 第一步 点击A和1的交界处全选...第二步 点击开始->格式->隐藏和取消隐藏->取消隐藏行/列 还有一种比较高端的方法 写VBA Sub showAll() Cells.Rows.Hidden = 0 Cells.Columns.Hidden
如果我们使用的mysql是5.7版本,我们则可以使用mysql5.7版本提供的一个新特性--虚拟列来达到上述效果虚拟列在mysql5.7支持2种虚拟列virtual columns 和 stored columns...,支持在MyISAM和InnoDB引擎创建索引mysql5.7 默认的虚拟列类型为virtual columns 1、创建虚拟列语法ALTER TABLE 表名称 add column 虚拟列名称 虚拟列类型...b、虚拟列字段只读,不支持 INSRET 和 UPDATEc、只能引用本表的非 generated column 字段,不可以引用其它表的字段d、使用的表达式和操作符必须是 Immutable 属性,比如不能使用...一次用作虚拟列的值,一次用作索引中的值3、虚拟列的使用场景a、虚拟列可以简化和统一查询,将复杂条件定义为生成的列,可以在查询时直接使用虚拟列(代替视图)b、存储虚拟列可以用作实例化缓存,以用于动态计算成本高昂的复杂条件...大体介绍了一下虚拟列,如果是使用mysql8.0.13以上的版本,可以函数索引,他的实现方式本质也是基于虚拟列实现。
1 条记录,才开始发送给客户端,发送了 limit 条记录之后,查询结束。...虽然知道了是什么,也知道了为什么,但是我也一直好奇底层是怎么实现的,所以今天我们来扒一扒它的庐山真面目。 1....所以,在这一步要判断已发送记录数量(send_records)和需要发送的记录数量(select_limit_cnt)之间的关系,如果已发送记录数量大于等于需要发送的记录数量,则结束查询,否则就接着进入第...不过这种方案也有个问题,不支持跳着翻页,只支持顺序翻页(就是每次都点下一页的这种)。 如果要支持跳着翻页,怎么办?...ID,然后用这些主键 ID 去 MySQL 中查询对应的数据,从而用两把锤子间接的实现了分页功能。
优化分页查询 在MySQL中做分页查询,MySQL 并不是跳过 offset 行,而是取 offset+N 行,然后返回放弃前 offset 行,返回 N 行,那当 offset 特别大的时候,效率就非常的低下...例如“limit 1000,20”,此时MySQL排序出前1020条数据后仅仅需要第1001到1020条记录,前1000条数据都会被抛弃,查询和排序的代价非常高。...第一种优化思路 在索引上完成排序分页的操作,最后根据主键关联回表查询所需要的其他列内容。 画外音:此处涉及到了SQL优化的两个重要概念,索引覆盖和回表,我在前面的文章中详细介绍过这两个概念。...通过索引覆盖在索引上完成扫描和排序(索引有序),最后通过主键(InnoDB引擎索引会通过主键回表)回表查询,最大限度减少回表查询的I/O次数。...总结 对于嵌套查询和分页查询的优化,归根结底就是遵循SQL优化原则之一——减少回表查询的I/O次数。对于分页查询优化,更建议使用第一种优化方案,性能更好,稳定性更高。 参考 《深入浅出MySQL》
mobile_no列,括号外为从user_table表中检索mobile_id为10086的所有行中的user_id列; PS:select语句中,子查询总是从内向外处理(实际上,MySQL执行了2个select...格式化SQL:包含子查询的select语句一般相较来说阅读和调试更为不方便,特别是它比较复杂的情况下,因此把子查询分解为多行并且适当缩进,能极大的简化子查询的使用。...表和usertable表中的user_id列。...PS:使用子查询建立查询的最可靠方法是逐渐进行(首先建立最内层的查询,确认后用硬编码数据建立外层查询,由内到外) 二、组合查询 MySQL允许执行多个查询(多条select语句),并将结果作为单个查询结果集返回...union使用规则: ①union必须由两条或以上的select语句组成,语句之间用关键字union分隔; ②union中每个查询必须包含相同的列、表达或聚集函数(各个列不需要以相同的次序列出); ③列数据类型必须兼容
领取专属 10元无门槛券
手把手带您无忧上云