0 评论

0 收藏

分享

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

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

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




v2-8cc20831038eadc785c5e23439c7f86c_720w.png








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

这是反馈来的查询代码,也就是有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 我们开始进入内部技术讨论环节




v2-48fc7c2a8e8b6da4ec1e1944324c5202_720w.png








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




v2-c937b5510213b944a63ede2f2963923e_720w.png








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




v2-3de32e7f14b8ccf43786fc8e472039df_720w.png











v2-83e3051ea2f93ca3b34a48b1630398ee_720w.png








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




v2-a2569e804bca01c882f5e5c5e4277169_720w.png








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




v2-b1b3099987a9a86e036ed149e78b859b_720w.png











v2-ba5e56a54a182796b59291a9206f163a_720w.png








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




v2-9cf0a7738837ec857d07930559f52f51_720w.png








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



v2-e39a67a6dd262affabb8765dfbbb5738_720w.gif








最终成果展示
//通过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;



0.png

优雅草论坛2022年8月11日大改,优雅草论坛变回只服务于客户的提问交流论坛,详情查看优雅草8月11日大改,原因详情查优雅草外卖乐关闭

回复

举报 使用道具

相关帖子
全部回复
暂无回帖,快来参与回复吧
一颗优雅草科技 实名认证 机构蓝V认证
服务代表
主题 855
回复 1655
粉丝 7