数据库查询语句优化,数据库结构优化,细节以及结果展示,

始于我们一个比较大的客户他的并发较高用户访问较多,造成CPU过于打紧然后得到了反馈情况。

首先是收到反馈,并且客户发来一段代码。

这是反馈来的查询代码,也就是有bug的代码(去年研发系统比较急,优化没做):

SELECT
`v`.`id`,
`v`.`title`,
`v`.`url`,
`v`.`img`,
`v`.`create_time`,
`v`.`uid`,
`v`.`state`,
`u`.`name`,
ifnull( u.head_img, 'static/image/head.png' ) head_img,
count( DISTINCT s1.id ) skr_count,
ifnull( s.skr, '0' ) skr,
ifnull( co.create_time, '0' ) collection,
ifnull( f.id, '0' ) follow,
count( DISTINCT c.id ) comment_count,
count( DISTINCT h.id ) view_count
FROM
tp_video v
LEFT JOIN `tp_skr` `s` ON `v`.`id` = s.vid
AND s.type = 0
AND '25712' = s.uid
LEFT JOIN `tp_skr` `s1` ON `v`.`id` = s1.vid
AND s1.type = 0
LEFT JOIN `tp_user` `u` ON `v`.`uid` = `u`.`id`
LEFT JOIN `tp_follow` `f` ON `v`.`uid` = f.follow_id
AND f.uid = '25712'
LEFT JOIN `tp_collection` `co` ON `v`.`id` = co.vid
AND co.uid = '25712'
LEFT JOIN `tp_view_history` `h` ON `v`.`id` = `h`.`vid`
LEFT JOIN `tp_comment` `c` ON `v`.`id` = c.vid
AND c.pid = 0
AND c.type = 0
WHERE
`v`.`state` = 1
GROUP BY
`v`.`id`
ORDER BY
`create_time` DESC
LIMIT 0,
20

ok 我们开始进入内部技术讨论环节

第一阶:目前认为索引优化用处不是特别大,但是有一点作用。

第二阶段:认为需要拆sql数据库

第三阶:开始质疑拆了是有用吗?讨论拆了以后会好,讨论sql数据量越大越慢,主要是因为全表查询。

第四阶:用主键索引 然后再拆,再查询

第五阶:测试并且得出效果,ok,完整成果如下,更新至官方1.9.2版本,效果展示,速度超6666~

YYC松鼠短视频系统1.9.2至此更新效果展示

最终成果展示

//通过ID获取已看视频ID$vids = Db("view_history")->where(["uid" => $user['id']])->field("vid")->select();$ids = array_column($vids, "vid");;//通过已看视频ID获取未看视频并通过发布时间倒序排序//查询20条视频数据的ID$videos = Db("video")->page($page,20)->where(['state'=>1])->whereNotIn('id',$ids)->field("id")->select();$videoids = array_column($videos, "id");$list = Db("video v")->whereIn("v.id", $videoids)->join("skr s", " v.id=s.vid and s.type=0 and '" . $user['id'] . "'=s.uid", "left")->join("skr s1",  "v.id=s1.vid and s1.type=0", "left")->join("user u", "v.uid=u.id", "left")->join("follow f","v.uid=f.follow_id and f.uid = '".$user['id']."'","left")//视频发布者ID等于被关注人ID并且关注用户ID等于当前用户ID->join("collection co","v.id=co.vid and co.uid = '".$user['id']."'","left")//视频ID等于收藏的视频ID并且收藏的用户ID为当前用户ID->join("view_history h", "v.id=h.vid", "left")->join("comment c", "v.id=c.vid and c.pid=0 and c.type=0", "left")->order("skr desc")->group("v.id")->field(["v.id",//视频ID"v.title",//视频标题"v.url",//视频链接"v.img",//视频图片"v.create_time",//视频创建时间"v.uid",//视频对应用户ID"v.state",//视频状态"u.name",//视频发布人名称"ifnull(u.head_img,'static/image/head.png') head_img",//用户头像"count(distinct s1.id) skr_count",//点赞数"ifnull(s.skr,'0') skr",//当前用户是否点赞"ifnull(co.create_time,'0') collection",//当前用户是否收藏"ifnull(f.id,'0') follow",//当前用户是否关注"count(distinct c.id) comment_count",//评论数"count(distinct h.id) view_count",//播放次数])->select();return $list;

数据库查询语句优化,mysql优化,join语句优化附带YYC松鼠短视频系统详细demo效果相关推荐

  1. Mysql数据库(九)——mysql高阶语句(下)

    Mysql数据库(九)--mysql高阶语句(下) 一.函数 1.数学函数 2.聚合函数 3.字符串函数 4.日期时间函数 二.存储过程 1.简介 2.优点 3.语法 ①.例 ②.参数分类 ③.带参数 ...

  2. 关于mysql中Join语句的几个问题

    本文来说下关于mysql中Join语句的几个问题,JOIN语句在平时的开发中还是使用的非常多的 文章目录 概述 基本介绍 举个例子 一个注意点 Join原理 Simple Nested-Loop In ...

  3. Mysql数据库(八)——mysql高阶语句(中)

    Mysql数据库(八)--mysql高阶语句(中) 一.正则表达式(同shell脚本的正则表达式) 1.以"."代替任意一个字符 2.匹配前面字符多次 3.匹配前面字符至少一次 4 ...

  4. Mysql数据库(七)——mysql高阶语句(上)

    Mysql数据库(七)--mysql高阶语句(上) 一.按关键字排序 1.单字段排序 2.多字段排序 二.或/且的运用 三.查询不重复记录 四.对结果进行分组 五.限制结果条目 六.设置别名 使用场景 ...

  5. MySQL8.0优化 - 优化MySQL服务器、优化MySQL的参数、优化数据类型

    文章目录 学习资料 优化MySQL服务器 优化服务器硬件 配置较大的内存 配置高速磁盘系统 合理分布磁盘I/O 配置多处理器 优化MySQL的参数 innodb_buffer_pool_size ke ...

  6. mysql 单表查询 优化_SQL优化 MySQL版 - 单表优化及细节详讲

    单表优化及细节详讲 作者 : Stanley 罗昊 [转载请注明出处和署名,谢谢!] 注:本文章需要MySQL数据库优化基础或观看前几篇文章,传送门: B树索引详讲(初识SQL优化,认识索引):htt ...

  7. QQ群关系库数据库查询解决方案,sql引索语句。

    前言 前些日子装数据库的笔记本硬盘炸了,不得不从云盘里恢复了数据,但是相应的一些数据库的优化又从头构造.昨天在DBA大神的帮助下再次优化了一下QQ群关系库的引索,前后查询只需要1 - 2秒,已经可以说 ...

  8. mysql的join语句使用_在MySQL中使用JOIN语句进行连接操作的详细教程

    到目前,我们已经学习了从一个表中获取数据.这是简单的需要,但在大多数现实MySQL的使用,经常需要将数据从多个表中的一个单一的查询. 可以使用多个表中的单一SQL查询.在MySQL中联接(join)行 ...

  9. babun登陆mysql_SQL优化 MySQL版 - 多表优化及细节详讲

    多表优化及细节详讲 作者 : Stanley 罗昊 [转载请注明出处和署名,谢谢!] 注:本文章需要MySQL数据库优化基础或观看前几篇文章,传送门: B树索引详讲(初识SQL优化,认识索引):htt ...

  10. mysql单台跨数据库查询_在MySQL中怎样进行跨库查询?

    在MySQL中跨库查询主要分为两种情况,一种是同服务的跨库查询:另一种是不同服务的跨库查询:它们进行跨库查询是不同的,下面就具体介绍这两种跨库查询. 一.同服务的跨库查询 同服务的跨库查询只需要在关联 ...

最新文章

  1. nginx参数优化杂记
  2. Mysql5.7的gtid主从半同步复制和组复制
  3. 上海人工智能实验室牛雅哲:通用决策AI平台的开拓创新之路
  4. QT4.8界面设计(MSVC2010X)+位姿哈希+ICP结果
  5. IBASE category 设置为01的情况下 IBASE自动创建情况
  6. Oracle发布Oracle数据库的官方Node.js驱动node-oracledb
  7. 基于QEMU的ARM Cortex-A9开发板Vexpress-ca9的Linux内核的编译和运行
  8. 计算机组成原理脱机运算器实验数据,实验三:脱机运算器实验报告.pdf
  9. 部署Azkaban多节点分布式模式
  10. php获取笔顺矢量,php如何获取汉字笔画数功能的实例分析
  11. QQ斗地主记牌器(只支持角色版)
  12. 报考软件资格考试过程详解--附学习分享
  13. C#应用程序界面开发基础——窗体控制(6)——菜单栏、工具栏和状态栏控件
  14. Python语言—爬虫之旅
  15. redis客户端通过哨兵获取主机、从机信息
  16. 网页部署https后浏览器访问风险提示或者您的链接不是私密链接解决方案
  17. 统计图配色方案_填充
  18. 上海科技大学计算机浙江分数线,上海科技大学2020录取分数线 上海科技大学录取分数线各省汇总...
  19. expect command
  20. Java高效输入输出流讲解

热门文章

  1. 数据结构STL——golang实现前缀基数树radix
  2. 机器之心的进化 / 理解 AI 驱动的软件 2.0 智能革命
  3. 图标快速定位工具 ElementUI FontAwesome iView
  4. 函数的支集、支撑集、support、supp
  5. 用Python绘制漫天繁星
  6. Word 题注重新编号
  7. java中display中的属性_全面解析display属性
  8. A granted authority textual representation is required
  9. verilog 7段数码管译码器
  10. ★三个和尚与机构臃肿的故事