数分面试题-SQL高频考点

目录标题

      • 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

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Jmeter实现生成全局参数-随机数

我在做项目的过程中&#xff0c;用的比较多的是【前置处理中】-用户参数 步骤一&#xff1a;添加参数处理器 步骤二&#xff1a;填写项目中可能会用到的一些参数&#xff08;固定的或者随机的都可以&#xff09; teacher_name${__RandomString(1,赵钱孙李周吴郑王冯陈褚卫蒋沈…

计算机网络(谢希仁版)基础期末复习

一、前言 该篇文章是对计算机网络&#xff08;谢希仁版&#xff09;常考的期末复习知识点进行的总结&#xff0c;可以供大家进行简单的复习&#xff0c;适用于网络工程、计算机网络类专业的同学进行复习使用。其他对计算机网络感兴趣的同学、相关专业人士也可进行阅读。 二、第…

SpringBoot第27讲:SpringBoot集成MySQL - MyBatis 多个数据源

SpringBoot第27讲&#xff1a;SpringBoot集成MySQL - MyBatis 多个数据源 本文是SpringBoot第27讲&#xff0c;在某些场景下&#xff0c;Springboot需要使用多个数据源&#xff0c;以及某些场景会需要多个数据源的动态切换。本文主要介绍上述场景及 SpringBootMyBatis实现多个数…

数据湖真的能取代数据仓库吗?【SNP SAP数据转型 】

数据湖和数据仓库的存在并不冲突&#xff0c;也并不是取代的关系&#xff0c;而是相互的融合关系。 数据湖是近两年中比较新的技术在大数据领域中&#xff0c;对于一个真正的数据湖应该是什么样子&#xff0c;现在对数据湖认知还是处在探索的阶段&#xff0c;像现在代表的开源产…

[SUCTF2019]hardcpp

前言 又遇到ollvm了 解混淆 可以直接用angr运行脚本去除除控制流平坦化&#xff0c;最好在ancoda等管理环境里面安装angr不然问题很多 https://github.com/Pure-T/deflat 去除前 去除后&#xff0c;它将多余的直接nop了 分析 主要加密区域位于匿名函数这一块&#xff0c…

Kafka 小结

Kafka 是由 Linkedin 开发并开源的分布式消息系统&#xff0c;因其分布式及高吞吐率而被广泛使用&#xff0c;现已与 Cloudera Hadoop、Apache Storm、Apache Spark、Flink 集成。 Kafka 使用场景 页面访问量 PV、页面曝光 Expose、页面点击 Click 等行为事件&#xff1b;实时计…

uniapp中uni-popup的用法——实例讲解

uni-pop弹出层组件&#xff0c;在应用中弹出一个消息提示窗口、提示框等,可以设置弹出层的位置&#xff0c;是中间、底部、还是顶部。 如下图效果所示&#xff1a;白色区域则为弹出的pop层。 一、 创建一个自定义组件&#xff1a; 1.项目中安装下载uni-pop插件。 2.把pop内容…

同一局域网内IP 192.168.1.10 和 IP 10.10.10.8 可以互相访问吗?

同一局域网内IP 192.168.1.10 和 IP 10.10.10.8 可以互相访问吗&#xff1f; 1、网上邻居的方式&#xff1a; 鼠标点击 我的电脑 属性 计算机名&#xff0c;查看一下 计算机名&#xff08;这个可以点击更改&#xff0c;自己设定和更改&#xff09; 查看一下工作组&#xff0c;一…

Python———PyCharm下载和安装

&#xff08;一&#xff09;开发环境介绍 开发环境&#xff0c;英文是 IDE &#xff08; Integrated Development Environment 集成开发环境&#xff09;。 不要纠结于使用哪个开发环境。开发环境本质上就是对Python 解释器python.exe 的封装&#xff0c;核心都一样。可以说&…

PostgreSQL使用localhost可以连接,使用IP无法连接

问题描述&#xff1a;PostgreSQL使用localhost可以连接&#xff0c;使用IP无法连接 默认情况下&#xff0c;刚安装完成的 postgresSQL12 无法使用 数据库连接工具&#xff08;如postman&#xff09;连接。需要为其修改配置&#xff0c;开放连接权限。 修改pg_hba.conf 增加…

采用VMD按照某一坐标轴旋转坐标结构

关注 M r . m a t e r i a l , \color{Violet} \rm Mr.material\ , Mr.material , 更 \color{red}{更} 更 多 \color{blue}{多} 多 精 \color{orange}{精} 精 彩 \color{green}{彩} 彩&#xff01; 主要专栏内容包括&#xff1a; †《LAMMPS小技巧》&#xff1a; ‾ \textbf…

深入理解深度学习——BERT派生模型:BART(Bidirectional and Auto-Regressive Transformers)

分类目录&#xff1a;《深入理解深度学习》总目录 UniLM和XLNet都尝试在一定程度上融合BERT的双向编码思想&#xff0c;以及GPT的单向编码思想&#xff0c;同时兼具自编码的语义理解能力和自回归的文本生成能力。由脸书公司提出的BART&#xff08;Bidirectional and Auto-Regre…

java文件夹上传,保留文件夹结构

需求: 产品要求可以上传文件夹,文件夹下包含其他文件夹 前端上传文件夹,可以把文件以及所在文件所在文件夹信息传到后端 1.前端设置 需要设置 webkitdirectory enctype multipart/form-data <!DOCTYPE html> <html> <head><meta charset"UTF-8&…

应用层:动态主机配置协议(DHCP)

1.应用层&#xff1a;动态主机配置协议(DHCP) 笔记来源&#xff1a; 湖科大教书匠&#xff1a;应用层概述 湖科大教书匠&#xff1a;动态主机配置协议(DHCP) 声明&#xff1a;该学习笔记来自湖科大教书匠&#xff0c;笔记仅做学习参考 如何配置用户主机才能使用户主机正常访问…

【数据科学赛】2023大模型应用创新挑战赛 #¥10万 #百度

CompHub 主页增加了“近两周上新的奖金赛”&#xff0c;更加方便查找最新比赛&#xff0c;欢迎访问和反馈&#xff01; 以下内容摘自比赛主页&#xff08;点击文末阅读原文进入&#xff09; Part1赛题介绍 题目 2023大模型应用创新挑战赛 举办平台 Baidu AI Studio 主办方…

Java设计模式之一:观察者模式

目录 一、什么是观察者模式 二、如何使用观察者模式 三、观察者模式的优势和使用场景 一、什么是观察者模式 观察者模式是一种常见的设计模式&#xff0c;用于在对象之间建立一对多的依赖关系。在该模式中&#xff0c;一个主题&#xff08;被观察者&#xff09;维护了一个观…

力扣 93. 复原 IP 地址

题目来源&#xff1a;https://leetcode.cn/problems/restore-ip-addresses/description/ C题解&#xff1a;递归回溯法。 递归参数&#xff1a;因为不能重复分割&#xff0c;需要ind记录下一层递归分割的起始位置&#xff1b;还需要一个变量num&#xff0c;记录ip段的数量。递…

陪诊小程序系统|陪诊软件开发|陪诊系统功能和特点

随着医疗服务的逐步改善和完善&#xff0c;越来越多的人群开始走向医院就诊&#xff0c;而其中不少人往往需要有人陪同前往&#xff0c;这就导致了许多矛盾与问题的发生&#xff0c;比如长时间等待、找不到合适的陪诊人员等。因此为人们提供一种方便快捷的陪诊服务成为了一种新…

【实战】 二、React 与 Hook 应用:实现项目列表 —— React17+React Hook+TS4 最佳实践,仿 Jira 企业级项目(二)

文章目录 一、项目起航&#xff1a;项目初始化与配置二、React 与 Hook 应用&#xff1a;实现项目列表1.新建文件2.状态提升3.新建utils4.Custom Hook 学习内容来源&#xff1a;React React Hook TS 最佳实践-慕课网 相对原教程&#xff0c;我在学习开始时&#xff08;2023.0…

ClickHouse主键索引最佳实践

在本文中&#xff0c;我们将深入研究ClickHouse索引。我们将对此进行详细说明和讨论&#xff1a; ClickHouse的索引与传统的关系数据库有何不同ClickHouse是怎样构建和使用主键稀疏索引的ClickHouse索引的最佳实践 您可以选择在自己的机器上执行本文给出的所有Clickhouse SQL…