当前位置: 首页 > news >正文

做网站外包好做吗万荣网站seo

做网站外包好做吗,万荣网站seo,深圳市市场监督管理局官网,学习网页设计与制作的网站你写的每条SQL都是全表扫描吗#xff1f;如果是#xff0c;那MySQL可太感谢你了#xff0c;每一次SQL执行都是在给MySQL上压力、上对抗。MySQL有苦难言#xff1a;你不知道索引吗#xff1f;你写的SQL索引都失效了不知道吗#xff1f;慢查询不懂啊#xff1f;建那么多索…你写的每条SQL都是全表扫描吗如果是那MySQL可太感谢你了每一次SQL执行都是在给MySQL上压力、上对抗。MySQL有苦难言你不知道索引吗你写的SQL索引都失效了不知道吗慢查询不懂啊建那么多索引干嘛呢。。。 文章目录 1. 慢查询2. SQL优化2.1 表设计优化2.2 SQL语句优化2.3 索引如何设计 未完待续。。。 1. 慢查询 面试官知道MySQL慢查询吗 MySQL的慢查询日志可以记录执行时间超过阈值的SQL查询语句所以我们可以利用该日志查找出哪些SQL语句执行效率差从而对SQL语句进行优化。 MySQL5.7以上版本可以通过SET命令来开启慢查询日志。 SET GLOBAL slow_query_logON;SET GLOBAL long_query_time2;SET SESSION long_query_time2;开启完慢查询日志我们找到该日志的位置打开文件即可查询慢查询的SQL。 查询慢查询日志文件位置SHOW VARIABLES LIKE %slow_query_log_file%;打开DESKTOP-ALU4BOC-slow.log文件找到慢查询SQL为select sleep(11)。 D:\MySQL\bin\mysqld, Version: 5.5.40 (MySQL Community Server (GPL)). started with: TCP Port: 3306, Named Pipe: MySQL Time Id Command Argument # Time: 220828 21:40:28 # UserHost: root[root] localhost [127.0.0.1] # Query_time: 11.004454 Lock_time: 0.000000 Rows_sent: 1 Rows_examined: 0 use mysql; SET timestamp1661694028; select sleep(11);2. SQL优化 2.1 表设计优化 面试官在工作中你怎么优化SQL的 业务开发中涉及数据库的第一步是表设计要优化SQL就要从第一步开始做起。 MySQL表设计要尽可能满足数据库三大范式帮助大家回顾下 第一范式数据库表中的每一列都是不可再分的属性属性相近或相同的列应该合并。 第二范式满足第一范式的条件下一个表只能描述一个对象。如果某些列经常出现数据重复应该把这些列作为另一个表。 第三范式满足第二范式的条件下表中的每一列都只能依赖于主键即直接与主键相关。 我们在业务开发中遇到反第二范式的情况是最多的例如以下订单明细表的设计每一个订单明细都包含了重复的商品名称、商品单位、商品价格这三个字段属于字段冗余存储。如果表的数据量级很大那造成的冗余存储量是可想而知的而且最要命的问题是如果要修改某一个商品名称那所有的订单明细数据都要修改。 我们可以遵循第三范式把冗余的字段抽出一个新的商品表当要查询订单明细时只需要把两表通过商品id进行连接即可。 面试官遵循第二范式就一定最优 遵循第二范式的表设计不一定是最优的情况还是那句话要根据实际的业务场景权衡利弊。 虽然把冗余数据抽离出去了但却增加了表的数量也意味着查询数据时表之间的join连接操作也会变多。而join连接的性能是比较低的有可能join操作会成为数据库性能的瓶颈。 2.2 SQL语句优化 面试官还有呢 SQL优化除了做好表设计的优化工作还需要对SQL语句进行优化。而SQL查询语句的优化主要从覆盖索引、避免索引失效、减少不必要的查询三个方面入手。 一、从覆盖索引的角度。 order by排序的字段要尽量覆盖索引。如果使用非索引字段进行排序MySQL会进行额外的文件排序将查询结果根据非索引列在磁盘中再排序一次。当我们使用explain关键字分析SQL时会发现Extra会出现Using filesort。 group by分组要尽量覆盖索引。如果使用非索引字段进行分组MySQL只能进行全表扫描后建立临时表才能得出分组结果。 另外我们可以使用explain关键字来分析SQL语句的效率查看SQL语句是否覆盖索引。 二、从避免索引失效的角度。 关于如何避免索引失效大家可以阅读我出版的《JavaGetOffer》专栏关于【MySQL索引】的文章。 三、从减少不必要的查询的角度。 如果只需要查询部分列尽量不要使用select *查询防止造成不必要的资源消耗、占用过多的网络带宽。 2.3 索引如何设计 面试官在工作中表索引你怎么设计的 索引的设计有以下设计原则大家在实际业务开发中应该尽量遵循这些原则可以帮你避开不少坑。 经常进行order by排序、group by分组、join多表联结查询的字段应该建立索引。 经常在where子句中出现的字段应该建立索引。 尽量使用数据量小的字段建立索引。例如对于char(500)和char(10)两个字段类型来说肯定是以后者进行索引匹配的速度更快。 如果需要建立索引的字段值比较长可以使用值的部分前缀来建立索引。 例如varchar类型的name字段我们需要根据前三个字符来建立前缀索引可以使用以下SQL命令ALTER TABLE example_table ADD INDEX index_name (name(3))。 面试官那索引建立越多查询效率就越高吗 另外大家记住一点索引不是建立越多越好。合理设计的索引确实能大大提高SQL效率但每建立一个字段索引MySQL就要为该索引多维护一棵B-Tree越多的索引会造成表更新效率变得低下。 以【面试官面试】形式覆盖Java程序员所需掌握的Java核心知识、面试重点本博客收录在我开源的《Java学习指南》中会一直完善下去希望收到大家的 ⭐ Star ⭐支持这是我创作的最大动力 https://github.com/hdgaadd/JavaGetOffer 未完待续。。。 创作不易不妨点赞、收藏、关注支持一下各位的支持就是我创作的最大动力❤️
http://www.hkea.cn/news/14570850/

相关文章:

  • wordpress调用主站的文章wordpress自动安装
  • 做引流网站怎么赚钱赚谁的钱绿色wordpress主题模板
  • 果洛营销网站建设哪家好wordpress如何cdn加速
  • 网站建设定位分析论文深圳市宝安区
  • 网站建设 流程郑州网站建设汉狮
  • seo整站网站推广优化排名黄骅港招聘最新招聘
  • 网站建设合同不给版权百度竞价sem入门教程
  • 网站建设与软件开发哪个好赚钱wordpress新建菜单
  • 阿里云建wordpress站做美食没有广告的网站
  • 网站gzip压缩重庆新闻联播回看
  • 网站建设的基础知识与维护兰州做网站 东方商易
  • 开网站赚钱分销平台官网
  • 营销外包网站定制化网站开发一般多少钱
  • 口碑好的网站建设公司哪家好产品展示栏目在网站中的作用
  • 网站建设公司的转型wordpress大学主题1.3
  • 潍坊网站制作软件怎么搭建网站 优帮云
  • 网站开发服务税率是多少当前主流的网站开发语言
  • 青岛网站建设公司招聘山东网站建设口碑好
  • 绿色环保材料网站模板python基础教程第二版
  • 上传下载网站模板安徽海鹏建设工程有限公司网站
  • 门户网站用什么程序做Wordpress怎么改成中文
  • 邢台医院网站建设深圳市住房和建设局红色警示查询
  • 网站 测速度搜索引擎优化时营销关键词
  • 百度有没有做游戏下载网站吗wordpress 文章样式
  • 怎么建设淘宝联盟的网站网站倒计时怎么做
  • 网站维护运营好做吗河南网站托管
  • 深圳凌 网站开发黄埔网站开发
  • 湘西北京网站建设上海装修公司排名统帅
  • 网页游戏网站搭建建设有限公司首页
  • 做网站还是做游戏wordpress 文章系统