数分面试题-SQL高频考点

news2024/12/30 3:08:33

目录标题

      • 1、SQL语言分类
      • 2、join连接
      • 3、列转换
        • 3.1 列转行
        • 3.2 行转列
      • 4、分页查询
      • 5、字符串处理函数
        • 5.1 字符函数
        • 5.2 数学函数
        • 5.3 日期函数
      • 6、索引
        • 6.1 什么是索引
        • 6.2 建立索引的优缺点
        • 6.3 索引有哪些
        • 6.4 索引为什么快
        • 6.5 什么情况下加索引
        • 6.6 怎么知道索引用没用上
        • 6.7 用过组合索引吗,是有序的吗
        • 6.8 什么情况下会使索引失效?
        • 6.9 sql优化您们是怎么做的?
      • 7、Mysql建表考虑因素
      • 8、数据库事务的四大特性
      • 9、drop、delete与truncate的区别
      • 10、查询执行流程

1、SQL语言分类

  • DQL数据查询语言select
  • DML数据管理语言:insert update delete
  • DDL数据定义语言: create update alter
  • TCL事务控制语言: commit rollback

2、join连接

(1)内连接:inner join
等值连接
非等值连接
自连接
(2)外连接:
左外连接left join
右外连接right join
全外连接full join
在这里插入图片描述
(3)交叉连接cross join
笛卡尔乘积现象:表1有m行,表2有n行,结果是m*n行
笛卡尔乘积发生原因:没有有效的连接条件
笛卡尔乘积如何避免:添加有效的连接条件

3、列转换

3.1 列转行

原表:
在这里插入图片描述
输出:
在这里插入图片描述

select t1.id,name
from t lateral view explode(split(list,'|')) as name

3.2 行转列

select t1.id,concat_ws('|',collect_set(t1.name))
from animal_info t1
group by t1.id

4、分页查询

当前要显示的数据,一页显示不全,需要分页提交SQL请求
语法:
select
from a join b on 条件
group by
having
order by
limit offset,size;

offset要显示条目的起始索引(索引从0开始)
size要显示的条目个数
执行顺序:from , join ,on , where,group by,having ,select ,order by ,limit

5、字符串处理函数

5.1 字符函数

  • length :获取字节个数,一个字母是一个字节,一个汉字是三个字节(utf-8)或者两个字节(gdk)

  • concat :拼接字符串。concat(字段1,字段2 ,。。)

  • upper,lower:大小写

  • substr:
    substr(‘12345678’,7)截取从指定索引处后面的所有字符
    substr(‘12345678’,7)截取从指定索引处指定字符长度的字符

  • instr(‘qwertyu’,‘t’)返回字串第一次出现的索引,如果找不到返回0

  • trim去除前后字符
    select trim(’ 张翠山 ') as output

  • lpad用指定的字符实现左填充指定长度
    select lpad(‘硬生生’,10,‘*’) as output

  • replace替换
    select replace(‘张无忌爱上了周芷若’,‘周芷若’,‘赵敏’)

5.2 数学函数

round 四舍五入
ceil 向上取整
floor 向下取整
truncate 截断
select truncate(1.699,1) 输出1.6
mod取余数 mod(10,3)=1

5.3 日期函数

now 返回当前系统日期+时间
curdate 返回当前系统日期,不包含时间
year()month()day()截取年月日
date_format(‘2018/6/3’,‘%Y年%m月%d日’)

6、索引

6.1 什么是索引

索引指数据库的目录。比如:字典上面的字母目录(适用于大数据量)

6.2 建立索引的优缺点

优点:查询速度快
缺点:增删改慢,因为数据要同步取维护索引文件,所以速度慢

6.3 索引有哪些

普通、主键、唯一组合

6.4 索引为什么快

索引结构:B+Tree

6.5 什么情况下加索引

(1)主键自动建立唯一索引
(2)频繁作为查询条件的字段应该创建索引
(3)查询中与其他表关联的字段,外键关系建立索引
(4)单键/组合索引的选择问题,组合索引的性价比更高
(5)查询中排序的字段,排序字段若通过索引去访问将大大提高排序速度
(6)查询中统计或者分组字段。
(7)过滤条件好的字段选择一段选择加索引

6.6 怎么知道索引用没用上

通过explain查询sql执行计划,主要看key使用的是哪个索引

6.7 用过组合索引吗,是有序的吗

用过, 有序

6.8 什么情况下会使索引失效?

(1)like
(2)like “%123%,前面不能+%
(3)使用 关键字 in ,or ,null,!=

6.9 sql优化您们是怎么做的?

(1)首先开启数据库慢查询日志,定位到查询效率比较低的sql , 找出对应的sql语句并进行分析

  • 表设计是否规范,是否符合三范式的标准
    第一范式:保证原子性(不可拆分)
    第二范式:每张表都有主键
    第三范式:每一列都有主键相关
  • 查看数据表中是否存在大量的冗余字段,字段数据类型是否合理
  • 尽可能的使用varchar代替char 建表数据类型,能用数值的绝对不用字符存储
  • 尽量避免null值,使用默认值替代空值,数值型可以使用0,字符型可以使用空字符串

(2)查看sql语句是否规范

  • 避免使用关键字:or ,in,not in ,!=,<>,避免使用select *
  • 尽量避免子查询,大部分子查询都可以连接查询
  • 用到or的地方可以使用union去代替实现
  • 用到in的地方可以使用exists去代替
    (3)分析sql的索引是否可以用上
  • explain查询sql的执行计划,重点关注的几个列就是,type是不是全表扫描
  • 看一下索引是否能够用的上,主要看key使用的是哪个索引
  • 看一下rows扫描行数是不是很大

7、Mysql建表考虑因素

1、表名
2、字段类型
时间格式的数据有:date、datetime和timestamp等等可以选择。
字符类型的数据有:varchar、char、text等可以选择。
数字类型的数据有:int、bigint、smallint、tinyint等可以选择。
3、字段长度
在mysql中除了varchar和char是代表字符长度之外,其余的类型都是代表字节长度。
4、字段个数——不超过20个

8、数据库事务的四大特性

ACID:持久性 隔离性 一致性 原子性
原子性:原子性是指事务包含的所有操作要么全部成功,要么全部失败回滚。
一致性:是指事务必须使数据库从一个一致性状态变换到另一个一致性状态,也就是说一个事务执行之前和执行之后都必须处于一致性状态。
隔离性:是当多个用户并发访问数据库时,比如操作同一张表时,数据库为每一个用户开启的事务,不能被其他事务的操作所干扰,多个并发事务之间要相互隔离。
持久性:是指一个事务一旦被提交了,那么对数据库中的数据的改变就是永久性的,即便是在数据库系统遇到故障的情况下也不会丢失提交事务的操作。

事务隔离级别:读未提交(1000)、读已提交(1100)、可重复读(1110)、串行化(1111)。

9、drop、delete与truncate的区别

drop、delete、truncate都表示删除,但是三者有一些差别:
1、Delete用来删除表的全部或者一部分数据行,执行delete之后,用户需要提交(commmit)或者回滚(rollback)来执行删除或者撤销删除。会触发这个表上所有的delete触发器
2、Truncate删除表中的所有数据,这个操作不能回滚,也不会触发这个表上的触发器,TRUNCATE比delete更快,占用的空间更小;
3、Drop命令从数据库中删除表,所有的数据行,索引和权限也会被删除,所有的DML触发器也不会被触发,这个命令也不能回滚。

因此,在不再需要一张表的时候,用drop;在想删除部分数据行时候,用delete;在保留表而删除所有数据的时候用truncate。

10、查询执行流程

简单来说分为五步:① 客户端发送一条查询给服务器。② 服务器先检查查询缓存,如果命中了缓存则立刻返回存储在缓存中的结果,否则进入下一阶段。③ 服务器端进行 SQL 解析、预处理,再由优化器生成对应的执行计划。④ MySQL 根据优化器生成的执行计划,调用存储引擎的 API 来执行查询。⑤ 将结果返回给客户端。
from - join - on - where - groupby - having - select - orderby - limit

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

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

相关文章

Axure教程—中继器删除与批量删除

本文介绍的是用Axure中的中继器实现删除与批量删除效果 效果 功能 1、选中某项数据删除&#xff0c;删除后提示“删除成功” 2、选择多项数据删除&#xff0c;删除后提示“删除成功”&#xff0c;如果不选取数据&#xff0c;点击”批量删除“按钮&#xff0c;提示”请至少选择…

SNMP 计算机网络管理 一文理清-管理信息库,OID,MIB结构树,SNMP协议体系结构

⬜⬜⬜ &#x1f430;&#x1f7e7;&#x1f7e8;&#x1f7e9;&#x1f7e6;&#x1f7ea;(*^▽^*)欢迎光临 &#x1f7e7;&#x1f7e8;&#x1f7e9;&#x1f7e6;&#x1f7ea;&#x1f430;⬜⬜⬜ ✏️write in front✏️ &#x1f4dd;个人主页&#xff1a;陈丹宇jmu &am…

Java接口详解

目录 接口方法 接口的属性 接口方法 在Java设计的时候, 我们所说的接口,不同于类,我们尝尝希望一个类能满足某个特定的功能,或者需求. 我们在使用Arrays类中的sort方法对对象数组进行排序,但是对象所属的类必须实现Comparable接口: 可以看到里面只有一个方法: public inter…

【动态规划算法】第二题:⾯试题08.01.三步问题

&#x1f496;作者&#xff1a;小树苗渴望变成参天大树 &#x1f389;作者宣言&#xff1a;认真写好每一篇博客 &#x1f38a;作者gitee:gitee 如 果 你 喜 欢 作 者 的 文 章 &#xff0c;就 给 作 者 点 点 关 注 吧&#xff01; 文章目录 前言 前言 今天我们开始讲解动态规…

MySQL数据库总结 之 约束(restraint) 外键约束

前三篇关于MySQL的博客&#xff0c;地址如下&#xff1a; 1. MySQL数据库 && SQL语言命令总结 && 数据类型、运算符和聚合函数汇总_Flying Bulldog的博客-CSDN博客 2. 从0到1 && 关于MySQL的数据库和表_Flying Bulldog的博客-CSDN博客 3. MySQL数据…

Protobuf实现序列化和反序列化详细步骤

步骤1&#xff1a;添加对应的依赖 <dependency><groupId>com.google.protobuf</groupId><artifactId>protobuf-java</artifactId><version>3.7.1</version> </dependency>步骤2&#xff1a;编写bulid.bat文件执行&#xff0c…

react组件--npm发包总过程(超全教程!建议收藏!)

npm发包总过程 npm账号登录注册&#xff08;已有账号可跳过&#xff09;登录验证是否登录成功创建组件项目目录图新建文件夹&#xff0c;并初始化安装依赖/src/index.js --打包入口文件src/components/button/index.js --组件逻辑代码src/components/button/index.css --组件逻…

10 次面试 9 次被刷?吃透这 500 道大厂 Java 高频面试题后,怒斩 offer

很多 Java 工程师的技术不错&#xff0c;但是一面试就头疼&#xff0c;10 次面试 9 次都是被刷&#xff0c;过的那次还是去了家不知名的小公司。 问题就在于&#xff1a;面试有技巧&#xff0c;而你不会把自己的能力表达给面试官。 应届生&#xff1a;你该如何准备简历&#x…

verilog HDL -生成块 - generate——endgenerate

参考&#xff1a;vrilog数字系统设计 夏宇闻 【第3版】 5.7 生成块理解 生成语句可以动态的生成verilog代码&#xff0c;方便参数化模块的生成&#xff0c;大大的简化程序的编写过程,常用于以下情况&#xff1a; 对矢量中的多个位进行重复操作进行多个模块的实例引用的重复操…

Anacoda3中成功配置Tesseract-OCR超详细教程!!(win7、win10)

Anacoda3中成功配置Tesseract-OCR Tesseract-OCR简介安装及配置环境步骤1、在Anaconda虚拟环境中安装pytesseract第三方库2、下载tesseract-ocr安装包并安装3、环境配置检验是否安装成功修改pytesseract.py文件&#xff08;很重要&#xff01;&#xff09; Tesseract-OCR简介 …

C语言常用的数据转换函数

编程时&#xff0c;经常用到进制转换、字符转换。现整理记录如下&#xff1a; 一、字符串转十六进制 void StrToHex(char *pbDest, char *pbSrc, int nLen) {char h1,h2;char s1,s2;int i;for (i0; i<nLen/2; i){h1 pbSrc[2*i];h2 pbSrc[2*i1];s1 toupper(h1) - 0x30; …

ASP.NET Core MVC -- 控制器

添加控制器 访问测试 默认控制器访问index public string Index() {return "This is my default action..."; }特定访问路径 public string Welcome() {return "This is the Welcome action method..."; } 特定路径访问&#xff0c;带参数 public str…

查询Oracle当前用户下,所有数据表的总条数

需求&#xff1a;查询Oracle当前用户下&#xff0c;所有数据表的总条数 方法&#xff1a;存储过程 右键点击Procedures&#xff0c;点击New 点击OK 把存储过程写进去&#xff0c;然后点击编译运行&#xff1a; create or replace procedure tables_count ist_count numbe…

dolphinscheduler的switch组件

目录 一、背景 switch组件官方文档 Switch简介 创建任务 任务参数 二、实操DEMO SQL任务switch判断DEMO 第一步&#xff1a;新建SQL任务&#xff0c;配置好参数 第二步&#xff1a; 定义SWITCH节点 三、参考资料 默认任务参数 一、背景 Apache DolphinScheduler 是…

B站广告投放,B站有哪些投放广告的方式比较靠谱?

随着各视频平台发展&#xff0c;B站也逐渐壮大&#xff0c;成为当下最受年轻人喜爱的社交媒体平台之一&#xff0c;B站根据年轻人的喜好提供了多样化的产品和服务&#xff0c;如视频、直播、游戏、漫画、影业、演出活动、专栏等。形成了自己独特的up主文化。B站拥有着高黏性和高…

如何保证消息的可靠性传输?或者说,如何处理消息丢失的问题?

这个是肯定的&#xff0c;用 MQ 有个基本原则&#xff0c;就是数据不能多一条&#xff0c;也不能少一条&#xff0c;不能多&#xff0c;就是 前面说的重复消费和幂等性问题。不能少&#xff0c;就是说这数据别搞丢了。那这个问题你必须得考 虑一下。 如果说你这个是用 MQ 来传…

基于单片机心率脉搏心率血压体温血氧检测系统的设计与实现

功能介绍 本次设计通过32系列单片机STM32进行数据处理&#xff0c;配置引脚和JFC103传感器以及温度传感器进行数据通信。采用防水DS18B20进行腋下温度采集&#xff0c;通过单总线方式进行数据传输。心率血氧血压模块通过串口通信方式把采集到的数据发送给单片机&#xff0c;所有…

mac版本的xshell远程ssh工具

官网下载地址&#xff1a; https://www.royalapps.com/ts/win/download 注意&#xff1a;一定要保存(下载安装之后记得一定要点击&#xff1a;Apply & Close&#xff0c;保存设置) 使用

Transactional outbox pattern

文章目录 Transactional outbox pattern事件驱动架构(Event Driven Architecture, EDA)数据库事务和消息发布的一致性问题Transactional outbox如何解决数据事务和消息发布之间的一致性问题如何实现Transactional outbox pattern消息幂等性问题Transactional outbox pattern能保…

百万连接实现01:使用epoll+多线程+多IP地址管理tcp客户端集群

操作系统采用 <客户端IP : 客户端端口> : <服务端IP : 服务端端口> 四元组来标识一条TCP连接。 所以要想实现百万连接&#xff1a; 第一种是服务器端只开启一个进程&#xff0c;然后使用很多个客户端进程绑定不同的客户端 ip 来连接&#xff0c;假设 20个ip * 5w&a…