自建网站的步骤/近期热点新闻事件50个

自建网站的步骤,近期热点新闻事件50个,淮北哪有做淘宝网站,迪庆网站建设一、索引创建的原则 1、针对数据量较大,且查询比较频繁的表建立索引。 单表超过10万数据,即可增加索引 2、使用经常作为查询条件(where)、排序(order by)、分组(group by)操作的字…

一、索引创建的原则

1、针对数据量较大,且查询比较频繁的表建立索引。

单表超过10万数据,即可增加索引

2、使用经常作为查询条件(where)、排序(order by)、分组(group by)操作的字段建立索引

3、尽量选择区分度高的字段作为索引,尽量建立唯一索引,区分度越高,使用的索引越高效。

例如下图中的address,区分度太小就不适合作为索引

4、尽量使用联合索引(多个字段),减少单列索引,查询的时候,联合索引很多时候可以用到“覆盖索引”,节省存储空间,避免“回表查询”,提高查询效率

5、索引也不是越多越好,尽量控制索引的数量

索引越多,维护索引结构的代价越大,在增删改的时候效率也越低

6、如果要建立索引的列不能存储null值,请在创建表时,使用not null约束,可以增加查询效率

二、什么情况下索引会失效

首先讲一个我碰到的真实案例:

我们公司系统有一张大表,有80多个字段(按照规范其实不应该有这么多字段,历史遗留问题,后面在数据库国产化的时候,准备优化),每天500万-2000万之间的订单数据;原来是使用日期作为分区键,再走主键索引查询的;

结果有一次代码改动,这张表又加了几个字段,而且在其中一条SQL的select 后加上了几个字段,oracle的索引就既不走分区键,也不走主键索引了,通过查看执行计划发现,是执行到了另外几个字段的普通联合唯一索引上,而我们除了select后加了字段以外,where条件没有改动。

出现的现象:应用更新上去后,立马开始告警,数据库连接超时,告警数据库连接池满。新进来的请求无法下单,大面积异常。决定立马执行回退操作;

回退完成(业务正常)后,开始分析原因:除了加了几个字段以外,select 后加了几个字段要查询出来以外,也没有增加改动索引,也没有where条件的任何改动;后面分析执行计划发现索引走偏了,走到另一个普通索引上了

原因分析为:

Oracle优化器会根据查询的代价(Cost)来选择执行计划。当查询中涉及的字段或数据量发生变化时,优化器可能会重新评估使用不同索引的代价。例如:

  • 新添加的字段可能使得查询结果集的大小或数据分布发生了变化,导致优化器认为使用其他索引更高效。

  • 如果查询涉及的字段在新索引中能够覆盖查询所需的所有列(即覆盖索引),优化器可能会优先选择该索引

当然,在我碰到的这次案例中,oracle优化器,显然是帮了倒忙,选择了错误的索引,导致查询时间超长,占用连接池

解决方案:联系DBA人员,强行绑定执行的索引,使用分区键+主键,问题解决

后续又碰到一次类似的问题,但是我们预料到可能出现这样的情况,提前联系了DBA人员支撑,一出现这个问题,就立马绑定索引;

索引失效的条件:

1、违反最左前缀原则

即:当使用一个联合索引(索引了多列)时,查询条件中,,要从索引的最左前列开始,并且不跳过索引中的列,匹配最左前缀法则,走索引

例如:tb_seller表有一个联合索引,是name、status、address三个字段的联合索引;

上述两条SQL执行,没有带上name字段,所以我们可以看到执行计划中,key和key_len都没有表现出这条SQL走了索引,索引失效

2、范围查询右边的列,不能使用索引

即,如果一个联合索引,某个字段使用了范围查询,那么这个字段后面的索引都不能生效

例如:还是上面这个表,第一条SQL使用了正确的联合索引,执行计划的key显示使用了索引tb_seller_index,索引长度key_len显示612,表示用到了name、status、address三个字段的索引,这三个字段的长度,加起来一共是612

而第二条SQL的条件中,status约束了查询范围“>1”,导致address这个字段的索引没有走到,key_len的长度就只有309了,只使用到了name和status

3、不要在索引列上进行运算操作,索引会失效

即:如果对有索引的列,使用运算操作,那么索引可能会失效

如图,还是这张表,组合索引是(name、status、address)

图中的SQL的执行计划中,key为null,说明没有走到索引,导致索引失效,这样查询会很慢

4、字符串不加单引号,造成索引失效

在查询时,如果没有对字符串加单引号,MySQL的查询优化器,会自动的进行类型转换,造成索引失效

上图中的SQL,第一条正确的SQL的执行计划,能够看到key_len是309,是使用了name、status两个字段的索引;

而第二条SQL的执行计划中,key_len是303,仅仅使用了name这个字段上的索引,造成了status上的索引失效;

原因是:第二条SQL条件中字符串类型的字段status后面的=跟的是0,没有带字符串,MySQL就认为是数字类型,而要与status相匹配,则要转换成字符串类型 ;而进行的类型转换,导致了索引失效

5、以%开头的like模糊查询,索引失效。

但是如果仅仅是尾部模糊匹配,索引不会失效。如果是头部模糊匹配,索引失效。

如图中,第一条,第二条SQL中,组合索引统统失效,第三条中,%在末尾,并没有导致索引失效

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/70051.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

内容中台重构企业内容管理流程驱动智能协作升级

内容概要 内容中台作为企业数字化转型的核心基础设施,通过技术架构革新与功能模块整合,重构了传统内容管理流程的底层逻辑。其核心价值在于构建动态化、智能化的内容生产与流转体系,将分散的创作、存储、审核及分发环节纳入统一平台管理。基…

【性能测试】如何理解“10个线程且10次循环“的请求和“100线程且1次循环“的请求

在性能测试中,我们常常会见到不同的并发配置:比如“10个线程且10次循环”与“100线程且1次循环”。乍一看,这两个设置的总请求数都是100次,但它们对系统的压力和测试场景却截然不同。了解其中的区别,能帮助你更精准地模…

【Golang】GC探秘/写屏障是什么?

之前写了 一篇【Golang】内存管理 ,有了很多的阅读量,那么我就接着分享一下Golang的GC相关的学习。 由于Golang的GC机制一直在持续迭代,本文叙述的主要是Go1.9版本及以后的GC机制,该版本中Golang引入了 混合写屏障大幅度地优化了S…

百度千帆平台对接DeepSeek官方文档

目录 第一步:注册账号,开通千帆服务 第二步:创建应用,获取调用秘钥 第三步:调用模型,开启AI对话 方式一:通过API直接调用 方式二:使用SDK快速调用 方式三:在千帆大模…

Natural Language Processing NLP

NLP 清晰版本查看 Sentence segmentation (split)Tokenisation (split)Named entity recognition (combine) 概念主要內容典型方法Distributional Semantics(分佈式語義)(分銷語義(分佈式語義)單詞的語義來自於它的…

Linux中线程创建,线程退出,线程接合

线程的简单了解 之前我们了解过 task_struct 是用于描述进程的核心数据结构。它包含了一个进程的所有重要信息,并且在进程的生命周期内保持更新。我们想要获取进程相关信息往往从这里得到。 在Linux中,线程的实现方式与进程类似,每个线程都…

HarmonyOS:使用List实现分组列表(包含粘性标题)

一、支持分组列表 在列表中支持数据的分组展示,可以使列表显示结构清晰,查找方便,从而提高使用效率。分组列表在实际应用中十分常见,如下图所示联系人列表。 联系人分组列表 在List组件中使用ListItemGroup对项目进行分组&#…

django上传文件

1、settings.py配置 # 静态文件配置 STATIC_URL /static/ STATICFILES_DIRS [BASE_DIR /static, ]上传文件 # 定义一个视图函数,该函数接收一个 request 参数 from django.shortcuts import render # 必备引入 import json from django.views.decorators.http i…

Office word打开加载比较慢处理方法

1.添加safe参数 ,找到word启动项,右击word,选择属性 , 添加/safe , 应用并确定 2.取消加载项,点击文件,点击选项 ,点击加载项,点击转到,取消所有勾选,确定。

内网下,Ubuntu (24.10) 离线安装docker最新版教程

一般在数据比较敏感的情况下,是无法使用网络的,而对于Ubuntu系统来说,怎么离线安装docker呢? 下面我给大家来讲一下: 采用二进制安装: 1.下载docker离线包 官网下载: Index of linux/static…

Copilot Next Edit Suggestions(预览版)

作者:Brigit Murtaugh,Burke Holland 排版:Alan Wang 我们很高兴向你介绍在本次 Visual Studio Code 发布中,关于 GitHub Copilot 的三个预览功能: Next Edit Suggestions(NES)Copilot Edits 的…

高性能内存对象缓存Memcached详细实验操作

目录 前提准备: cache1,2: 客户端cache-api(一定得是LAMP环境) memcache实现主主复制以及高可用(基于以上完成) cache1,2: memcachekeepalived(基于以上完成) cache1,2: 前提准备: 1. 准备三台cent…

Spring AI发布!让Java紧跟AI赛道!

1. 序言 在当今技术发展的背景下,人工智能(AI)已经成为各行各业中不可忽视的重要技术。无论是在互联网公司,还是传统行业,AI技术的应用都在大幅提升效率、降低成本、推动创新。从智能客服到个性化推荐,从语…

UART(一)——UART基础

一、定义 UART(Universal Asynchronous Receiver/Transmitter)是一种广泛使用的串行通信协议,用于在设备间通过异步方式传输数据。它无需共享时钟信号,而是依赖双方预先约定的参数(如波特率)完成通信。 功能和特点 基本的 UART 系统只需三个信号即可提供稳健的中速全双工…

【PHP】php+mysql 活动信息管理系统(源码+论文+数据库+数据库文件)【独一无二】

👉博__主👈:米码收割机 👉技__能👈:C/Python语言 👉专__注👈:专注主流机器人、人工智能等相关领域的开发、测试技术。 【PHP】php 活动信息管理系统(源码论文…

数据结构——单向循环链表、双链表、双向循环链表

目录 一、单向循环链表 1.1 单向循环链表的概念 1.2 单向循环链表的操作 1.2.1 单向循环链表的创建 1.2.2 单向循环链表的头插 1.2.3 单向循环链表的遍历 1.2.4 单向循环链表的头删 1.2.5 单向循环链表的尾插 1.2.6 单向循环链表的尾删 1.2.7 约瑟夫环 1.3 单向循环列表所有程…

wordpress资讯类网站整站打包

wordpress程序,内置了价值499元的模板.但是有了模板没有全自动采集相信大多数人都搞不懂,目录那么多,全靠原创几乎是不可能的事情,除非你是大公司,每人控制一个板块, 这套源码里面最有价值的应该是这个采集…

使用verilog 实现 cordic 算法 ----- 旋转模式

1-设计流程 ● 了解cordic 算法原理,公式,模式,伸缩因子,旋转方向等,推荐以下链接视频了解 cordic 算法。哔哩哔哩-cordic算法原理讲解 ● 用matlab 或者 c 实现一遍算法 ● 在FPGA中用 verilog 实现,注意…

教育小程序+AI出题:如何通过自然语言处理技术提升题目质量

随着教育科技的飞速发展,教育小程序已经成为学生与教师之间互动的重要平台之一。与此同时,人工智能(AI)和自然语言处理(NLP)技术的应用正在不断推动教育内容的智能化。特别是在AI出题系统中,如何…

VScode内接入deepseek包过程(本地部署版包会)

目录 1. 首先得有vscode软件 2. 在我们的电脑本地已经部署了ollama,我将以qwen作为实验例子 3. 在vscode上的扩展商店下载continue 4. 下载完成后,依次点击添加模型 5. 在这里可以添加,各种各样的模型,选择我们的ollama 6. 选…