网站虚拟主持海淀网站建设wzjs51

diannao/2026/1/18 20:51:10/文章来源:
网站虚拟主持,海淀网站建设wzjs51,广东公司响应式网站建设设计,经典重庆网站目录 前言1.char和varchar的区别2.数据库的三大范式3.你了解sql的执行顺序吗#xff1f;4.索引是什么5.索引的优点和缺点6.索引的类型7.索引怎么设计(优化)8.怎么避免索引失效(也属于sql优化的一种)9.索引的数据类型10.索引为什么使用树结构11.二叉查找树、B树、B树12.为什么使… 目录 前言1.char和varchar的区别2.数据库的三大范式3.你了解sql的执行顺序吗4.索引是什么5.索引的优点和缺点6.索引的类型7.索引怎么设计(优化)8.怎么避免索引失效(也属于sql优化的一种)9.索引的数据类型10.索引为什么使用树结构11.二叉查找树、B树、B树12.为什么使用B树不用B树13.最左匹配原则14.Mysql怎么查看是否使用到索引或怎么查看sql执行计划15.一条sql查询非常慢我们怎么去排查和优化16.MylSAM和InnoDB、Memory的区别17.什么是事务18.事务的四大特性(ACID)19.脏读、不可重复读、幻读20.事务的隔离级别21.怎么优化数据库22.SQL优化23.常用的聚合函数24.几种关联查询25.in和exists的区别26.drop、truncate、delete的区别 前言 java最新面试题(java基础、集合、多线程、jvm、锁、算法、CAS、Redis、数据库、mybatis、spring、springMVC、springBoot、微服务) 1.char和varchar的区别 ①char设置多少长度就是多少长度varchar可以改变长度所以char的空间利用率不如varchar的空间利用率高。 ②因为长度固定所以存取速度要比varchar快。 ③char适用于固定长度的字符串比如身份证号、手机号等varchar适用于不固定的字符串。 2.数据库的三大范式 第一范式(1NF) 保证字段不可再分保证原子性。 第二范式(2NF) 满足1NF前提下表的每一列都必须和主键有关系。消除部分依赖关系。 第三范式(3NF) 满足2NF前提下表的每一列比必须和主键有直接关系不能是间接关系。消除传递依赖 3.你了解sql的执行顺序吗 ⑧select ⑨distinct(去重) ⑥聚合函数 ①from 表1 ③[inner join | left join | right join](连接) 表2 ②on(连接条件) 表1.字段 表2.字段 ④where 查询条件 ⑤group by(分组) 字段 ⑦having 分组过滤条件 ⑩order by(排序) 字段 ⑪limit(分页) 0,10 4.索引是什么 是一种高效获取数据的数据结构相当于目录更快的找到数据是一个文件占用物理空间。 5.索引的优点和缺点 优点 ①提高检索的速度。 ②索引列对数据排序降低排序成本。 ③mysql 8之后引入了隐藏索引当一个索引被隐藏就不会被优化器所使用就可以看出来索引对数据库的影响有利于调优。 缺点 ①索引也是一个文件所以会占用空间。 ②降低更新的速度因为不光要更新数据还要更新索引。 6.索引的类型 ①普通索引 基本索引类型允许定义索引的字段为空值和重复值。 ②唯一索引 索引的值必须唯一允许定义索引的字段为空值。 ③主键索引 索引的值必须唯一不可以为空。 ④复合索引 多个字段加索引遵守最左匹配规则。 ⑤全局索引 只有在 MyISAM 引擎上才能使用。 7.索引怎么设计(优化) ①选择唯一性索引值是唯一的查询的更快。 ②经常作为查询条件的字段加索引。 ③为经常需要排序、分组和联合操作的字段建立索引order by、group by、union(联合)、distinct(去重)等。 ④限制索引个数索引数量多需要的磁盘空间就越多更新表时对索引的重构和更新就很费劲。 ⑤表数据少的不建议使用索引(百万级以内)数据过少有可能查询的速度比遍历索引的速度都快。 ⑥删除不常用和不再使用的索引。 ⑦用类型小的类型做索引比如int和BIGINT能用int就使用int。因为类型小查询速度快和索引占用的空间更少。 ⑧使用前缀索引要是字符串越长那么索引占的空间越大并且比较起来就时间就越长。 8.怎么避免索引失效(也属于sql优化的一种) ①某列使用范围查询(、、like、between and)时, 右边的所有列索引也会失效。 ②不要对索引字段进行运算。 ③在where子句中不要使用 OR、!、和对值null的判断。 ④避免使用’%开头的like的模糊查询。 ⑤字符串不加单引号造成索引失效。 9.索引的数据类型 Hash 查询时调用Hash函数获得地址回表查询实际数据。(InnoDB和MylSAM不支持Memory支持)。 B树 每次从根节点出发去查询然后得到地址回表查询实际数据。 10.索引为什么使用树结构 因为可以加快查询效率而且可以保持有序。 11.二叉查找树、B树、B树 二叉查找树(二叉排序树、二叉搜索树) 一个节点最多两个子节点(左小右大)查询次数和比较次数都是最小的但是索引是存在磁盘的当数据量过大的时候不能直接把整个索引文件加载到内存需要分多次IO最坏的情况IO的次数就是树的高度为了减少IO需要把树从竖向变成横向。 B树( B- ) 是一种多路查询树每个节点包含K个子节点节点都存储索引值和数据K是B树的阶(树高被称为树的阶)。虽然比较的次数比较多但是是在内存的比较可以忽略不计但是B树IO的次数要比二叉查找树要少因为B树的高度可以更低。 B树 B树的升级版只有叶子节点储存的是索引值指向的数据库的数据。 12.为什么使用B树不用B树 ①B树只适合随机检索而B树同时支持随机检索和顺序检索(因为叶子节点相当于链表保存索引值都是有序的)。 顺序检索 按照序列顺序遍历比较找到给定值。 随机检索 不断从序列中随机抽取数据进行比较最终找到结果。 ②减少了磁盘IO提高空间利用率 因为B树非叶子节点不会存放数据只有索引值所以非叶子节点可以保存更多的索引值这样B树就可以更矮减少IO次数。 ③B树适合范围查找 这才是关键因为数据库大部分都是范围查找B树的叶子节点是有序链表直接遍历就行而B树的范围查找可能两个节点距离很远只能通过中序遍历去查找所以使用B树更合适。 中序遍历 (根在中从左往右一棵树的左子树永远在根前面根永远在右子树前面 13.最左匹配原则 最左优先以最左边为起点任何连续的索引都能匹配上。同时遇到范围查询、、between and、like就会停止匹配。 例如Z表建立联合索引 (a,b,c) //这样索引abc列都起效因为符合最左匹配原则where子句几个搜索条件顺序调换不影响查询结果因为Mysql中有查询优化器会自动优化查询顺序 select * from Z where a 1 and b 2 and c 3 //因为a列是起点没有a列匹配不上所以索引失效 select * from table_name where b 2 and c 3 //因为连续不到b所以只有a列索引生效 select * from table_name where a 1 and c 3 14.Mysql怎么查看是否使用到索引或怎么查看sql执行计划 使用explain 例如explain select * from 表名 where 条件 结果会查出keykey就是你使用的索引。还有type这个字段可以看到索引是全表扫描还是索引扫描等等。 type字段内容性能对比ALL index range ~ index_merge ref eq_ref const system 15.一条sql查询非常慢我们怎么去排查和优化 排查 (1) 开启慢查询。 (2) 查看慢查询日志(定位低效率sql命令show processlist)。 (3) 使用explain查看sql的执行计划(看看索引是否失效或者性能低) 优化 sql优化 索引 数据库结构优化 优化器优化 16.MylSAM和InnoDB、Memory的区别 MylSAM mysql5.5之前的存储引擎是表锁悲观锁级别的不支持事务和外键。 InnoDB mysql5.5之后的存储引擎是行锁乐观锁级别的支持事务和外键。 Memory 内存数据库引擎因为在内存操作所以读写很快但是Mysql服务重启会丢失数据不支持事务和外键。 17.什么是事务 事务和隔离级别详解及实际应用 事务是对数据库中一系列操作进行统一的回滚或者提交的操作主要用来保证数据的完整性和一致性。 18.事务的四大特性(ACID) 原子性(Atomicity) 要么全部成功要么全部失败。 一致性(Consistency) 事务执行前和事务执行后原本和数据库一致的数据仍然一致。 隔离性(Isolation) 事务与事务之间互不干扰。 持久性(Durability) 事务一旦被提交了那么对数据库中的数据的改变就是永久的。 19.脏读、不可重复读、幻读 脏读 也叫读未提交顾名思义就是某一事务A读取到了事务B未提交的数据。 不可重复读 在一个事务内多次读取同一个数据却返回了不同的结果。实际上这是因为在该事务间隔读取数据的期间有其他事务对这段数据进行了修改并且已经提交就会发生不可重复读事故。 幻读 在同一个事务中第一次读取到结果集和第二次读取到的结果集不同。像幻觉一样所以叫幻读。 从上面可以看出脏读和不可重复读是基于数据值的错误幻读是基于条数增加或者减少的错误 20.事务的隔离级别 ① read uncommited(读取未提交内容) 在该隔离级别所有事务都可以看到其他未提交事务的执行结果。读取未提交的数据也被称之为脏读Dirty Read ② read committed(读取提交内容) 这是大多数数据库系统的默认隔离级别但不是MySQL默认的。一个事务只能看见已经提交事务所做的改变。可解决脏读 ③ repeatable read(可重读) 这是MySQL的默认事务隔离级别同一事务的多个实例在并发读取数据时会看到同样的数据。不过理论上这会导致另一个棘手的问题幻读Phantom Read。可解决脏读、不可重复读 ④ serializable(可串行化) 这是最高的隔离级别它通过强制事务排序使之不可能相互冲突从而解决幻读问题。简言之它是在每个读的数据行上加上共享锁。在这个级别可能导致大量的超时现象和锁竞争。可解决脏读、不可重复读、幻读。 21.怎么优化数据库 ①SQL优化 ②加缓存 ③分表 ④读写分离 22.SQL优化 ①不要用select *要使用具体字段。 ②使用数值代替字符串比如0唱1跳2rap。 ③避免返回大量数据采用分页最好。 ④使用索引提升查询速度不宜建太多索引不能建在重复数据比较多的字段上。 ⑤批量插入比单条插入要快因为事务只需要开启一次数据量太小体现不了。 ⑥避免子查询优化为多表连接查询。 ⑦尽量使用union all替代union因为union会自动去重。 23.常用的聚合函数 ①sum(列名) 求和      ②max(列名) 最大值      ③min(列名) 最小值      ④avg(列名) 平均值      ⑤first(列名) 第一条记录 ⑥last(列名) 最后一条记录 ⑦count(列名) 统计记录数不包含null值 count(*)包含null值。 24.几种关联查询 内连接(inner join) 查询两个表匹配数据。 左连接(left join) 查询左表全部行以及右表匹配的行。 右连接(right join) 查询右表全部行以及左表匹配的行。 25.in和exists的区别 in() 适合子表(子查询)比主表数据小的情况。 exists() 适合子表(子查询)比主表数据大的情况。 26.drop、truncate、delete的区别 速度 drop truncate delete。 回滚 delete支持truncate和drop不支持。 删除内容 delete表结构还在删除部分或全部数据不释放空间。truncate表结构还在删除全部数据释放空间。drop表结构和数据不在包括索引和权限释放空间。

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

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

相关文章

什么是最经典最常用的网站推广方式wordpress文件无法创建目录下

1、什么是线程池 java.util.concurrent.Executors提供了一个 java.util.concurrent.Executor接口的实现用于创建线程池 多线程技术主要解决处理器单元内多个线程执行的问题,它可以显著减少处理器单元的闲置时间,增加处理器单元的吞吐能力。 假设一个服…

网站统计模板江苏苏州

责任链模式概述 责任链模式(Chain of Responsibility Pattern)是一种行为设计模式,它允许对象或对象集合以链式的方式组织在一起,以处理请求在责任链中,每个对象都包含对下一个对象的引用,并且都有机会处理…

滨州建网站公司自建网站平台的页面功能

今天,在配置kettle同步mysql数据的时候,碰到了kettle把空字符串当成null的情况。 解决步骤: 找到配置文件:C:\Users\用户名.kettle目录中找到kettle.properties添加配置:KETTLE_EMPTY_STRING_DIFFERS_FROM_NULLY重启k…

那个视频网站好手机之家报价大全

知行EDI系统主要是用来实现贸易双方的数据交换的过程,这个过程中,贸易双方往往需要根据国际通用的消息格式收发信息,我们称符合国际规范的消息文件为EDI报文,然而不同的公司会结合ERP的接口情况选择不同的集成方式,例如…

手机网站信任从哪里设置企业营销策划及推广

jooq sqljOOQ是“数据库优先”类型的安全SQL API,使您可以直观地用Java编写SQL,就像Java编译器本身支持SQL语言一样。 所有数据库模式,表,列,过程和其他对象均作为Java对象提供,可以直接在jOOQ SQL API中使…

网站建设首选建站系统自建网站需要备案吗

项目需求 职工管理系统可以用来管理公司内所有员工的信息 公司中职工分为三类:普通员工、经理、老板,显示信息时,需要显示职工编号、职工姓名、职工岗位、以及职责 普通员工职责:完成经理交给的任务 经理职责:完成老…

admin5站长网五个h5制作网站

文章目录题意思路传送门 题意 给你nnn个点,需要给每个点定向,方向可以向右或者向左,定向之后点会朝选择的方向移动,要求满足mmm个条件,两种不同的条件如下: i,ji,ji,j两个位置定向之后移动不会相遇。i,ji…

做网站设计的公司名字哈尔滨市营商环境建设监督局网站

编写软件测试文档是一个关键步骤,它可以帮助测试人员记录测试过程、结果和发现的问题,同时为开发团队提供反馈和建议。 以下是一些编写软件测试文档的建议: 测试计划 在测试计划中,描述测试的目标、范围、方法、时间表和资源需求。…

网站建设怎么收费呀河西网站建设制作

【 组长博客链接】 031602428 苏路明 【计划安排】 阶段主要任务时间任务内容1项目选题09.22 - 10.10确定选题内容,收集用户需求,明确定位,竞品分析,选题报告2需求分析10.11 - 11.4梳理需求,输出思维导图,原…

东莞市建设规划局网站wordpress如何制作主题

Node.js 是一个基于 Chrome V8 引擎的 JavaScript 运行环境,它可以让 JavaScript 代码在服务器端运行。在 Node.js 中,fs 模块是用来处理文件系统操作的模块。通过 fs 模块,我们可以进行文件的读取、写入、删除等操作。本教程将介绍如何在 No…

电子商务网站详细设计百度推广工具有哪些

构建检索增强生成(RAG)系统的关键因素之一:向量嵌入( vector embeddings )。这些元素是基本的技术和转换工具,使 RAG 系统在某些方面能够以类似于人类理解的形式处理语言。 embedding 提供了一种将文本信息转换为数字数据的方法。…

定制网站制作报价3d建模学什么专业

大数据开发语言主要包括以下几个,以下是它们在大数据开发领域的优缺点和应用场景的详细说明: 1. Java 优点: 跨平台性:Java的“一次编写,到处运行”的特性使得其可以轻松地运行在多个操作系统上。面向对象&#xff…

仿牛商网营销型网站兖州网站建设多少钱

前言 故事是这样开始的。我们的小DEMO项目的数据库版本从openGauss 2.1.0升级到了5.0.0版本。升级后进行功能验证的时候,测试同学发现个BUG,原来通过gs_restore导出来的数据再导入时报超长,插入失败了,如下图所示,nva…

教学网站模板下载企业网站设计北京

参考资料 Guide to Faster, Less Frustrating Debugging 什么情况下会使用gbd 需要逆向ELF文件时(掌握gdb的使用,是二进制安全的基本功)开发程序时,程序执行结果不符合预期 动态调试ELF文件可以使用另外一种方法:IDA的远程linux动态调试。个…

网站正在建设中页面 英文诚信网站认证必需做吗

说明此时有两个客户端在连接此数据库&#xff0c;此时不能删除数据库。 如果确定要强制删除此数据库&#xff0c;那么执行如下命令&#xff1a; SELECT pg_terminate_backend(pg_stat_activity.pid) FROM pg_stat_activity WHERE datname‘VolteAna3G’ AND pid<>pg_ba…

扫码进入网站如何做做视频比较好的理财网站

文章目录 项目介绍主要功能截图:部分代码展示设计总结项目获取方式🍅 作者主页:超级无敌暴龙战士塔塔开 🍅 简介:Java领域优质创作者🏆、 简历模板、学习资料、面试题库【关注我,都给你】 🍅文末获取源码联系🍅 项目介绍 基于SpringBoot的校园生活服务平台,java…

网站备案 价格建行个人账户查询

目录 [LitCTF 2023]PHP是世界上最好的语言&#xff01;&#xff01; [LitCTF 2023]Vim yyds [羊城杯 2020]easycon [LitCTF 2023]PHP是世界上最好的语言&#xff01;&#xff01; 无参&#xff0c;根据题目提示看看php能否执行——返回1执行成功 用system()函数调用、执行ls …

怎么制作网站店铺wordpress照片加水印

为了方便日常运维写的一段简单脚本&#xff0c;用于集中获取服务器操作系统、CPU、内存使用、负载、硬盘使用、网络信息。 脚本比较简单&#xff0c;就不解释了&#xff0c;有兴趣的朋友请自行查看。 #!/bin/bash##Name:system_info#Ver:1.0#Author:lykyl###程序说明:#获取服务…

安全邮箱注册网站网站建设高校

花园管家是做什么的 一、工作内容职责&#xff1a; 1.管理花园内的活动和工作&#xff0c;协调各方资源&#xff0c;确保活动的顺利进行&#xff1b; 2.提供优质的客户服务和接待工作&#xff0c;解决客户问题&#xff0c;处理投诉&#xff0c;提高客户满意度&#xff1b; …