昨天需要用到全国所有省份、城市的JSON,结果网上找了好久没有合适的,还是自己搞一份吧。...有需要的同学去 点击打开链接下载 例子: { "Citys": [ { "Id": "245fc3c6-a77a-4bd6-8a46-35c2858c28be
作者:陈业贵 华为云享专家 51cto(专家博主 明日之星 TOP红人) 阿里云专家博主 文章目录 sql(省份表) sql(城市表) 省市表之间的联系是: province_id int unsigned...是不是得说这个城市属于哪一个省份呀 sql(城市表) CREATE table t_city( id int unsigned PRIMARY key AUTO_INCREMENT COMMENT..."主键", city varchar(200) not null COMMENT "城市", province_id int unsigned not null COMMENT "省份id"...) COMMENT="城市表"; 省市表之间的联系是: province_id int unsigned not null COMMENT “省份id” 城市是属于哪一个省份的呢 id int unsigned...身份证号是唯一能确定你这个人的,其他都可能有重复,所以,身份证号是主键。 设置主键的作用是唯一性。非空的。说明了自增的id不会重复的。 comment是什么? 代表一种注释。
一、效果图 📷 二、代码 1、index.html ...
子查询 2.1 概述 2.2 分类 2.3 标量子查询 2.4 列子查询 2.5 行子查询 2.6 表子查询 ️全篇总结 前言 在SQL查询中,自连接、联合查询和子查询是常用的高级查询技巧,能够帮助我们处理复杂的数据关联和逻辑运算...本篇文章将深入探讨这些高级查询技巧的语法结构、分类和常见应用,帮助读者更好地理解和运用这些技巧来解决实际的数据查询问题。 一....我们先来学习一下自连接的查询语法: SELECT 字段列表 FROM 表A 别名A JOIN 表A 别名B ON 条件 ... ; 而对于自连接查询,可以是内连接查询,也可以是外连接查询。...1.2 联合查询 对于union查询,就是把多次查询的结果合并起来,形成一个新的查询结果集。 SELECT 字段列表 FROM 表A ......SELECT之 2.3 标量子查询 子查询返回的结果是单个值(数字、字符串、日期等),最简单的形式,这种子查询称为标量子查询。 常用的操作符:= > >= < <= 案例: A.
一、mysql查询的五种子句 where(条件查询)、having(筛选)、group by(分组)、order by(排序)、limit(限制结果数) 1、where常用运算符...因为shop_price使用了max函数,那么它是取最大的,而语句中使用了group by 分组,那么goods_name并 没有使用聚合函数,它只是cat_id下的第一个商品,并不会因为shop_price...,看是否成立 2、字段(列),理解为变量,可以进行运算(算术运算和逻辑运算) 3、 取出结果可以理解成一张临时表 二、mysql子查询...(把两次或多次的查询结果合并起来,要求查询的列数一致,推荐查询的对应的列类型一致,可以查询多张表,多次查询语句时如果列名不一样,则取 第一次的列名!...,【即左右连接的结果去除null项后的并集(去除了重复项)】 mysql目前还不支持 外连接(即左右连接结果的并集,不去除null项) 语法:select n1,n2,n3
上一篇mysql统计账单信息(上):mysql安装及客户端DBeaver连接使用介绍了mysql5.7的安装及客户端DBeaver的连接配置,本文接上一篇内容,介绍数据导入和查询导出。...; 执行导入 导入过程可能会涉及到max_allowed_packet数值调整,设置max_allowed_packet数值更大些 mysql> show global variables like...'max_allowed_packet'; mysql> set global max_allowed_packet=16777216; 刷新查看 查看yd_csv表结构: 移动全量表明细...: 三、移动查询语句 查询语句基于restore导入的库表,也可以是导入的excel,这里以前者为例 1.查询语句 select liuliangkafukuan.yd_csv.卡号,liuliangkafukuan.yd_csv.ICCID...3.查询结果导出 选择输出的目录和文件名格式 导出如下:
今天在测试4000000条记录的mysql慢查询,数据库安装在windows上,百度了很多,都没有个测试可行的的解决方案或者经验之谈,可能是因为mysql版本不一样吧!...这里做个记录以备忘记时候可以查看,也让其他朋友借鉴一下。...这里用的mysql版本是5.6.17 首先,修改mysql中的my.ini文件,关键代码如下: datadir=”D:/MySQL5.6/MySQL Server 5.6/data\” log-output...”(慢查询日志文件,在上面的datadir目录之下) long_query_time=1(定义超过1秒的查询就是慢查询,测试时候用,生产环境应该根据实际需要调整在1到10之间的数) 然后,最后重新启动mysql...不过开启慢查询日志记录,将消耗资源,因此,生产环境下,应当按需开启,不应一直开启!!!
最近公司的系统一点点的开始了拆分,从ORACLE 转移到 MYSQL 中,部分程序员的想法在使用MYSQL中还是没有转变过来,直接将ORALCE中的查询语句直接搬到了MYSQL。...这就直接抛出一个问题,就是MYSQL的查询技巧还重要吗?当然如果你还要用MYSQL 来进行数据库的提取和查询,那就必须重视MYSQL的查询技巧。...下图是以 mysql 8.015 这个版本作为语句执行的基础 其实两条语句查询的结果是一样的,仅仅是写法不一样,给出的执行计划就是不一样的 以目前最新版本的MYSQL来说,从上面的例子里面,还是要鼓励直接查询...,后面其实我还做了一些其他的测试,例如将时间的范围扩大,发现目前的MYSQL 8.015 很聪明的走了应该走的索引,看了MYSQL8.0 这个版本的查询优化器要比MYSQL 5.7 进步不少。...最后,我们看看MYSQL 8.0的并行查询,并行查询,其实在 PG, SQL SERVER , ORACLE 中都有,但形式不同,MYSQL 8 之前是没有并行查询这个概念的,MYSQL 8 引入了并行查询
mysql 的连接查询 内连接 左连接 右连接 全连接 首先创建两张表,一个student_table,一个salary。表名起的不是合乎情景,就这样吧。...*,b.* from student_table a inner join salary b on a.id = b.sid; -- 内连接 得到的查询结果是 可以发现这个查询的显示就是根据id....* from student_table a full join salary b on a.id = b.sid; 但是mysql 8的版本还没有被支持,所以我们可以这样去实现全连接 select...然后再次进行一次全连接查询。...记录一下,Ctrl+G 调出替换窗口,将[object Object]替换为%5Bobject%20Object%5D就完事。 语雀这个太好用了。感觉非常丝滑,这个用来写笔记。
对于树结构的查询,在oracle数据库中有现成的函数直接调用,但是在mysql中这部分没有现成的函数可以直接调用,对于树形结构的递归遍历在实际业务中也是非常常见的。...本小节做一个记录 向下递归查询 SELECT ID.LEVEL, DATA.* FROM ( SELECT @ids AS _ids, ( SELECT @ids := GROUP_CONCAT
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语句等信息
今天来聊聊MySQL慢查询问题解决经验总结。 ? 高性能查询难题优化总结 我们来总结一下,应该如何处理高性能查询难题?...3.2 让SQL尽量符合查询优化器的执行要求 MySQL 查询优化器并不是对所有查询都适用的,我们可以通过改写查询 SQL 来让数据库更高效的完成工作。...MySQL v5.6版本以后,消除了很多MySQL原本的限制,让更多的查询能够以尽可能高的效率完成。...数据结构优化、索引设计优化及应用查询优化犹如三叉戟一般,齐头并进,在高性能查询应用中缺一不可。 写在最后 全文总结一下,其实就是我们要学会用数据库的要求方式来执行SQL。...其实MySQL查询优化中的每一项拆开讲都可以是很大的章节,在此主要是将解决问题的思路分享给大家,希望能对大家今后的工作中能有所帮助。 - END -
mySQL查询执行的过程 01 查询的流程图 当我们希望MySQL能够以更高的性能进行查询时,弄清楚MySQL中是如何优化和执行查询的就显得很有必要,这里,先搬出来一张图镇楼: ?...这张图写清楚了一个查询在MySQL中的执行过程: 1、客户端发送一条查询给服务器。 2、服务器先检查查询缓存,如果命中了缓存,则会进行权限校验,权限校验通过,直接返回结果。...3、如果没有命中缓存,则进行SQL解析、预处理、再由优化器进行查询优化,计算各项查询方法的成本、生成对应的执行计划。 4、MySQL根据执行计划,调用存储引擎的API来执行查询。...在我们查询的过程中,MySQL会维护一个查询状态,也就是我们使用show processlist来进行查看的时候的一些状态值,例如: sleep,说明线程正在等待客户端发送新的请求 query,线程正在执行查询或者正在将结果发送给客户端...sending data,这个状态表示服务器可能在多个状态之间传送数据或者在生成结果集想客户端返回 03 查询缓存 在解析查询的SQL的时候,如果这个查询时打开的,那么MySQL会优先在缓存中查询该
前言 Mysql的join是什么,join这个单词的意思是加入、参加、连接,而在数据库中,也是连接的意思,将两个表连接起来查询出我们想要的数据。...在数据库中,join的用法主要分成三种,分别是左连接、右连接和内连接,但是实际运用中,两个表之间的操作,是一共有七种,那我们今天就开始认识一下这七种用法吧 下面所有的椭圆都代表两个不同的表,假定左边为test1....png] test2表有uid、姓名、性别和年龄四个字段 1.全连接 如图,将这两张表全连接查询,假设A表有M条记录,B表有N条记录,全连接的时候就是用笛卡尔积来计算的,所以查询出来的是是M×N条记录...,如果没有数据就为空 总结:查询到的内容是两个表的所有内容 2.去交集 如图,将这两张表去交集连接查询,两个表的全连接去掉中间的交集的部分就是去交集 [7c1a9600623f2a5a0778bdd680e0d366...,去掉了101~107的公共部分,查询出来两个表独有的部分——test1的108、109,test2的100 总结:查询到的内容是两个表的没有公共部分的内容 3.左连接 如图,将这两张表进行左连接查询,
当希望 MySQL 能够以高性能的方式运行查询时,最好的办法就是弄清楚 MySQL 是如何优化和执行查询的。MySQL 执行一个查询的过程,如下: ?...开始执行的时候,要先判断一下你对这个表T有没有执行查询的权限,如果没有,就会返回没有权限的错误。...【4】MySQL 从不考虑其他并发执行的查询:可能会影响到当前查询的速度。 【5】MySQL 也并不是任何时候都是基于成本的优化:有时也基于一些固定的规则。...【7】子查询优化:MySQL 在某些情况下可以将子查询转换一种效率更高的形式,从而减少多个查询多次对数据进行访问。 【8】提前终止查询:如果发现已经满足查询需求,MySQL 总是能够立刻终止查询。...六、查询执行引擎 ---- 在解析和优化阶段,MySQL 将生成查询对应的执行计划,MySQL 的查询执行引擎则根据这个执行计划来完成整个查询。这里执行计划是一个数据结构,而不是字节码。
数据操作语言:分组查询 为什么要分组?...默认情况下汇总函数是对全表范围内的数据做统计 GROUP BY 子句的作用是通过一定的规则将一个数据集划分成若干个小的区域,然后针对每个小区域分别进行数据汇总处理 SELECT deptno,AVG(sal...查询语句中如果含有 GROUP BY 子句,那么 SELECT 子句中的内容就必须要遵守规定: SELECT 子句中可以包含聚合函数,或者 GROUP BY 子句的分组列,其余内容君不可出现在 SELECT...(sal),MIN(sal),count(*) FROM t_emp GROUP BY deptno WITH ROLLUP GROUP_CONCAT 函数 GROUP_CONCAT 函数可以把分组查询中的某个字段拼接成一个字符串...查询语句中,GROUP BY 子句应该被 第几个执行?
前言 虽然我们在前面已经出过一期关于表和库的操作了,这一次我们来更深入的介绍一下关于表的增删查改操作。...查询的列越多,意味着需要传输的数据量越大; -- 2. 可能会影响到索引的使用。...也就是我们可以自己定义查询表达式 案例: -- 表达式包含一个字段 //查询每个人的学号,姓名和对应的数学成绩加上100分 mysql> select id,name,math+100 from...] expr) 返回查询到的数据的 最大值,不是数字没有意义 MIN([DISTINCT] expr) 返回查询到的数据的 最小值,不是数字没有意义 1.count函数 案例: mysql> select.../MYSQL - 码云 - 开源中国 (gitee.com) 下载好到移到linux下 ,我们输入pwd指令获取到路径。
“ 在昨天的MySQL的查询优化(一)中,我们谈到SQL常用的一些优化方式:给字段增加索引,避免索引失效,替换掉一些不合理的关键词,那么今天我们继续来看SQL如何进行查询优化” 在上一章第一条优化中我们说到在...在MySQL5.6以后,Extra出现这句话表明,这条SQL语句优先去过滤索引,过滤完索引后找到所有符合索引条件的数据行。如果WHERE 还存在子句,再随后去过滤这些子句数据行。...来看一下:这里我想计算一下,状态为0和为1的数据量有多少。怎么实现呢?...SQL,如果开启了慢查询就去看慢查询日志,如果没有,把打印的SQL放到工具上执行一下,然后使用explain去看一下SQL的执行计划,最后再进行优化,当然最后的优化才是最重要的。...下面我再说一下另外一中优化方式:优化数据结构 一个好的数据库设计方案对于数据库的性能常常起到事半功倍的效果。
全列查询 语法:SELECT * FROM 表名; 通常情况下不建议使用 * 进行全列查询,因为: 查询的列越多,意味着需要传输的数据量越大; 可能会影响到索引的使用。...指定列查询 指定列的顺序不需要按定义表的顺序来,语法就是在 select 后跟上指定的字段列即可。...(2)截断表 语法: truncate [table] table_name 注意:这个操作慎用 只能对整表操作,不能像 delete 一样针对部分数据操作; 实际上 MySQL 不对数据操作,所以比...实例:创建一个新表,插入一个旧表中查询到的去重后的数据 先创建一个旧表,并插入数据: mysql> create table duplicate_table (id int, name varchar...(20)); mysql> INSERT INTO duplicate_table VALUES -> (100, 'aaa'), -> (100,
,如果我们使用了表的别名,在查询字段中、过滤条件中就只能使用别名进行代替,不能使用原有的表名,否则就会报错。...阿里开发规范: 【强制】对于数据库中表记录的查询和变更,只要涉及多个表,都需要在列名前加表的别名(或 表名)进行限定。...说明:对多表进行查询记录、更新记录、删除记录时,如果对操作列没有限定表的别名(或表名),并且操作列在多个表中存在时,就会抛异常。...`employee_id`; [在这里插入图片描述] 分类3:内连接 vs 外连接 除了查询满足条件的记录以外,外连接还可以查询某一方不满足条件的记录。...`department_id` = d.department_id; #只有106条记录 外连接:合并具有同一列的两个以上的表的行, 结果集中除了包含一个表与另一个表匹配的行之外,还查询到了左表 或
领取专属 10元无门槛券
手把手带您无忧上云