关于一个Java程序员马上要笔试了,临时抱佛脚,一晚上恶补45道简单SQL题,希望笔试能通过

news2025/1/23 10:45:29

MySQL随手练 / DQL篇

MySQL随手练——DQL篇

题目网盘下载:https://pan.baidu.com/s/1Ky-RJRNyfvlEJldNL_yQEQ?pwd=lana

初始数据

表 course
表 student
表 teacher
表 sc

答案 :) —> :( —> :)

1. 查询 "01"课程比"02"课程成绩高的学生的信息及课程分数

SELECT
	c.S,
	c.Sage,
	c.Sname,
	c.Ssex,
	a.C AS C1,
	a.score AS score1,
	b.C AS C2,
	b.score AS score2 
FROM
	sc a
	INNER JOIN sc b ON a.S = b.S
	INNER JOIN student c ON b.S = c.S 
WHERE
	a.C = '01' 
	AND b.C = '02' 
	AND a.score > b.score

1.1 查询同时存在" 01 “课程和” 02 "课程的情况

SELECT
	a.S,
	a.C AS C1,
	a.score AS score1,
	b.C AS C2,
	b.score AS score2 
FROM
	sc a
	INNER JOIN sc b ON a.S = b.S 
	AND a.C = '01' 
	AND b.C = '02'

1.2 查询存在" 01 “课程但可能不存在” 02 "课程的情况(不存在时显示为 null )

SELECT
	a.S,
	a.C AS C1,
	a.score AS score1,
	b.C AS C2,
	b.score AS score2 
FROM
	sc a
	LEFT JOIN sc b # RIGHT JOIN sc b
	ON a.S = b.S 
	AND b.C = '02' 
WHERE
	a.C = '01'

1.3 查询不存在"01 “课程但存在” 02 "课程的情况

SELECT
	a.S,
	a.C,
	a.score 
FROM
	sc a
	LEFT JOIN sc b ON a.S = b.S 
	AND b.C = '01' 
WHERE
	a.C = '02' 
	AND IFNULL( b.c, 'null' ) = 'null' 
# WHERE a.C = '02' AND b.c IS NULL

问题环节:


一、题1.2中为什么LEFT JOIN ON后面接AND 左表a.C = '01’无效?题1.2中为什么RIGHT JOIN ON 后面接AND 右表b.C = '02’无效?题1.1中为什么INNER JOIN ON 后面接AND 左表a.C = ‘01’ AND 右表b.C = '02’却有效呢?
实现INNER JOIN和OUTER JOIN都是按照ON后面条件进行条件判断后进行笛卡尔积拼接,将符合条件的数据行标记为true,最后根据各自的特性生成临时表。而区别就在这特性上面,INNER JOIN是全连接,只有两表中都符合ON AND后面条件的数据才会保留;OUTER JOIN是左外连接(右外连接),以左表(右表)为主体,右表(左表)有符合的数据就保留,没有展示null。通俗点讲:INNER JOIN和OUTER JOIN都是将两表中都符合ON AND后面条件的数据进行保留,但OUTER JOIN要满足自己的特性,所以会把不符合条件的数据用null展示,所以LEFT JOIN ON后面接AND 左表a.C = '01’无效和RIGHT JOIN ON 后面接AND 右表b.C = '02’无效,单纯就是进行了暗箱操作,我们没看到
二、IS NULL能不能优化一下?
IFNULL() > IS NULL > ISNULL()


2. 查询平均成绩大于等于60分的同学的学生编号,姓名和平均成绩

SELECT
	a.S,
	a.Sname,
	AVG( b.score ) AS score_avg 
FROM
	student a
	INNER JOIN sc b ON a.S = b.S 
GROUP BY
	a.Sname 
HAVING
	score_avg >= 60

问题环节:

一、分组聚合函数作用域?
DQL执行顺序:FROM > ON >JOIN > WHERE > GROUP BY > HAVING > SELECT > DISTINCT > ORDER BY > LIMIT
GROUP BY分组后才能使用,所以HAVING、SELECT、ORDER BY 都可以
二、DQL有执行顺序,那DML呢?
MySQL 采用了一种 WAL(先写日志再写磁盘) 技术,涉及两个日志文件和MySQL服务层及引擎层(InnoDB)(bin log和redo log:这部分不懂的,先去了解)。
下面针对以下这句DML语句进行分析:update table set value = ‘newValue‘ where id = 1;
简单推演: 从内存中取出id=1的那行数据(如果内存中不存在就从磁盘中查询并放入内存),修改对应字段数据,存入内存,等待回刷到磁盘。<解说存在一致性问题:服务层记录bin log,引擎层记录redo log>
初级推演:采用2PC保证 DML经过MySQL服务层执行器进入引擎层,InnoDB 引擎去查看当前内存中是否存在该数据行,如果存在之间从内存中取出,如果不在那么会从磁盘中 load 到内存之后再从内存中取出相应数据行,然后将数据行进行更新并将新行写入内存中,之后就会开始写日志,首先是 redo log的写入(此时进入prepare状态),最后进行事务的提交, bin log、redo log的写入(此时进入commit状态)
进阶推演: redo log三种形态(内存< redo log buffer >、文件系统缓存< page cache >、磁盘< disk >)。
DML经过MySQL服务层执行器进入引擎层,InnoDB 引擎去 引擎层buffer pool中获取id=1的数据行,不存在就从disk中获取然后load到 buffer pool。存在就从相应的数据页中取出给数据行进行修改再放入 buffer pool,同时将操作经过write position记录到redo log buffer(prepare状态)并且返回结果,事务提交, bin log、redo log的写入(此时进入commit状态)
究极推演: 由你完成,我顶不住了。。。。。。
三、简单介绍MySQL 8.0服务层
一条SQL语句的旅程:

  • 1、解析阶段:解析为一颗Parser Tree
  • 2、准备阶段:经历Resolve和Transform形成Abstract Syntax Tree
  • 3、优化阶段:SQL语句优化
  • 4、执行阶段:推向引擎层

3. 查询在sc表存在成绩的学生信息

SELECT
	a.S,
	a.Sname,
	a.Sage,
	a.Ssex 
FROM
	student a
	LEFT JOIN sc b ON a.S = b.S 
WHERE
	IFNULL( b.score, 'null' ) != 'null' 
GROUP BY
	a.S

问题环节:

一、DISTINCT a.S,a.Sname,a.Sage,a.Ssex失效?怎么指针对a.S去重?
首先并没有失效,需要a.S,a.Sname,a.Sage,a.Ssex都相同才能去重。
针对a.S去重,可以用GROUP BY a.S、DISTINCT(a.S)、GROUP_CONCAT(DISTINCT a.S)结合GROUP BY a.S


4. 查询所有同学的学生编号,学生姓名,选课总数,所有课程总成绩(没成绩显示为0)

SELECT
	a.S,
	a.Sname,
	COUNT( a.S ) AS course_sum,
	IFNULL( SUM( b.score ), 0 ) AS score_sum 
FROM
	student a
	LEFT JOIN sc b ON a.S = b.S 
GROUP BY
	a.S

问题环节:

一、替换函数?
IFNULL(b.score,0.0),COALESCE(b.score,0.0)


5. 查询李姓老师的数量

SELECT
	COUNT( t.T ) 
FROM
	teacher t 
WHERE
	t.Tname LIKE '李%'

6. 查询学过张三老师授课的同学信息

SELECT
	a.S,
	a.Sage,
	a.Sname,
	a.Ssex 
FROM
	teacher t
	LEFT JOIN course c ON t.T = c.T
	RIGHT JOIN sc b ON c.C = b.C
	RIGHT JOIN student a ON a.S = b.S 
WHERE
	t.Tname = '张三'

7. 查询没有学全所有课程的同学的信息

SELECT
	a.S,
	a.Sname,
	a.Sage,
	a.Ssex 
FROM
	student a
	LEFT JOIN sc b ON a.S = b.S 
GROUP BY
	a.S 
HAVING
	COUNT( a.S ) < ( SELECT COUNT( 1 ) FROM course )

8.查询至少有一门课与学号为" 01 "的同学所学相同的同学的信息

SELECT
	a.S,
	a.Sname,
	a.Sage,
	a.Ssex 
FROM
	sc b
	INNER JOIN sc d ON b.C = d.C
	LEFT JOIN student a ON d.S = a.S 
WHERE
	b.S = '01' 
	AND d.S <> '01' 
GROUP BY
	d.S

9. 查询和’01’号同学学习的课程完全相同的其它同学的信息

SELECT
	a.S,
	a.Sname,
	a.Sage,
	a.Ssex 
FROM
	sc b
	INNER JOIN sc d ON b.C = d.C
	LEFT JOIN student a ON d.S = a.S 
WHERE
	b.S = '01' 
	AND d.S <> '01' 
GROUP BY
	d.S 
HAVING
	COUNT( d.s ) = ( SELECT COUNT( S ) FROM sc WHERE S = '01' );

问题环节:

一、in会影响查询速度吗?
因值而定,in 的值不要超过 500 个,in 操作可以更有效的利用索引,那500哪里来的:IN查询字段值的个数受eq_range_index_dive_limit这个参数影响,建议个数不要超过该参数所配置的大小。
对于in值大的,可以分批查询,然后union all


10. 查询没有学过"张三"老师任意一门课程的学生信息

SELECT
	d.S,
	d.Sname,
	d.Sage,
	d.Ssex 
FROM
	course c
	INNER JOIN teacher t ON c.T = t.T 
	AND t.Tname = '张三'
	LEFT JOIN sc b ON c.C = b.C
	INNER JOIN student a ON a.S = b.S
	RIGHT JOIN student d ON a.S = d.S 
WHERE
	IFNULL( a.S, 'null' ) = 'null'

11. 查询两门课及以上不及格课程的同学的学号,姓名以及平均成绩

SELECT
	a.S,
	a.Sname,
	AVG( b.score ) AS score_avg 
FROM
	sc b
	INNER JOIN student a ON b.S = a.S 
	AND b.score < 60 LEFT JOIN sc d ON b.S = d.S GROUP BY b.S HAVING COUNT( b.S ) >= 2

问题环节:

一、笛卡尔积乘积会不会影响求平均值?
以上面答案中出现的情况是LEFT JOIN sc d 因为ON b.S = d.S都不是唯一id导致出现笛卡尔积乘积现象,但,并不会影响b.score求平均值,因为(SUM(b.score)*n)/(COUNT(b.score)*n),分子分母都乘上n


12. 检索" 01 "课程分数小于 60,按分数降序排列的学生信息

SELECT
	* 
FROM
	sc b
	INNER JOIN student a ON b.S = a.S 
	AND b.score < 60 
WHERE
	b.C = '01' 
ORDER BY
	b.S DESC

13. 按平均成绩从高到低显示所有学生的所有课程的成绩以及平均成绩

SELECT
	a.S,
	a.Sname,
	d.score,
	k.score_avg 
FROM
	(
	SELECT
		b.S,
		AVG( b.score ) AS score_avg 
	FROM
		sc b 
	GROUP BY
		b.S 
	ORDER BY
		AVG( b.score ) DESC 
	) k
	LEFT JOIN sc d ON k.S = d.S
	LEFT JOIN student a ON k.S = a.S

14. 查询各科成绩最高分、最低分和平均分:
以如下形式显示:课程 ID,课程 name,最高分,最低分,平均分,及格率,中等率,优良率,优秀率 及格为>=60,中等为:70-80,优良为:80-90,优秀为:>=90 要求输出课程号和选修人数,查询结果按人数降序排列,若人数相同,按课程号升序排列.

SELECT
	b.C,
	c.Cname,
	MAX( b.score ) AS score_max,
	MIN( b.score ) AS score_min,
	AVG( b.score ) AS score_avg,
	SUM(
	IF
	( b.score >= 60, 1, 0 ))/ COUNT( b.S ) AS pass_rate,
	SUM(
	IF
	( b.score >= 70 AND b.score < 80, 1, 0 ))/ COUNT( b.S ) AS medium_rate,
	SUM(
	IF
	( b.score >= 80 AND b.score < 90, 1, 0 ))/ COUNT( b.S ) AS excellent_rate,
	SUM(
	IF
	( b.score >= 90, 1, 0 ))/ COUNT( b.S ) AS excellence_rate,
	COUNT( 1 ) AS cons 
FROM
	sc b
	INNER JOIN course c ON b.C = c.C 
GROUP BY
	b.C 
ORDER BY
	COUNT( 1 ) DESC,
	b.C ASC

15. 按各科成绩进行排序,并显示排名

SELECT
	b.C,
	b.S,
	b.score,
	@rank := @rank + 1 AS rk 
FROM
	sc b,(
	SELECT
		@rank := 0 
	) AS t 
ORDER BY
	b.score DESC

15.1 按各科成绩进行排序,并显示排名, Score 重复时合并名次

SELECT
	b.C,
	b.S,
	@score := score AS score,
CASE
		
		WHEN @score = b.score THEN
		@rank ELSE @rank := @rank + 1 
	END AS rk 
FROM
	sc b,(
	SELECT
		@rank := 0,
		@score := 0 
	) AS t 
ORDER BY
	b.score DESC

16. 查询学生的总成绩,并进行排名,总分重复时保留名次空缺

SELECT
CASE
		
	WHEN
		@score = s.score_sum THEN
			'' ELSE @rank := @rank + 1 
			END AS rk,
		@score := s.score_sum AS score 
	FROM
		( SELECT SUM( score ) AS score_sum FROM sc GROUP BY S ORDER BY score_sum DESC ) s,(
		SELECT
			@rank := 0,
		@score := NULL 
	) t

17. 统计各科成绩各分数段人数:课程编号,课程名称,[100-85) ,[85-70),[70-60),[60-0]及所占百分比

SELECT
	c.C,
	c.Cname,
	COUNT( 1 ) AS '人数',
	SUM(
	IF
	( b.score > 85 AND b.score <= 100, 1, 0 ))/ COUNT( 1 ) AS '[100-85)',
	SUM(
	IF
	( b.score > 70 AND b.score <= 85, 1, 0 ))/ COUNT( 1 ) AS '[85-70)',
	SUM(
	IF
	( b.score > 60 AND b.score <= 70, 1, 0 ))/ COUNT( 1 ) AS '[70-60)',
	SUM(
	IF
	( b.score > 0 AND b.score <= 60, 1, 0 ))/ COUNT( 1 ) AS '[60-0]' 
FROM
	sc b
	INNER JOIN course c ON b.C = c.C 
GROUP BY
	b.C

18. 查询各科成绩前三名的记录

SELECT
	a.S,
	a.Sname,
	b.C,
	b.score 
FROM
	sc b
	LEFT JOIN sc d ON b.C = d.C 
	AND b.score < d.score
	RIGHT JOIN student a ON b.S = a.S 
GROUP BY
	b.S,
	b.C,
	b.score 
HAVING
	COUNT( 1 ) < 3 
ORDER BY
	b.C,
	b.score DESC

19. 查询每门课程被选修的学生数

SELECT
	b.C,
	COUNT( 1 ) 
FROM
	sc b 
GROUP BY
	b.C

20 . 查询出只选修两门课程的学生学号和姓名

SELECT
	* 
FROM
	sc b 
GROUP BY
	b.S 
HAVING
	COUNT( 1 )=2

21. 查询男生女生人数

SELECT
	a.Ssex,
	COUNT( a.Ssex ) AS sex_count 
FROM
	student a 
GROUP BY
	a.Ssex

22. 查询名字中含有「风」字的学生信息

SELECT
	a.S,
	a.Sname,
	a.Sage,
	a.Ssex 
FROM
	student a 
WHERE
	LOCATE( '风', a.Sname ) > 0

问题环节:

一、给’%风%'提提速
LOCATE(substr,str)、LOCATE(substr,str, pos)、POSITION(‘substr’ IN field)、FIND_IN_SET(str,strlist)


23. 查询同名同性学生名单,并统计同名人数

SELECT
	a.Sname,
	COUNT( 1 ) AS name_count 
FROM
	student a
	INNER JOIN student d ON a.Sname = d.Sname 
	AND a.S <> d.S

24. 查询 1990 年出生的学生名单

SELECT
	a.Sname 
FROM
	student a 
WHERE
	YEAR ( a.Sage ) = '2022'

25.查询每门课程的平均成绩,结果按平均成绩降序排列,平均成绩相同时,按课程编号升序排列

SELECT
	*,
	AVG( a.score ) 
FROM
	sc a 
GROUP BY
	a.C 
ORDER BY
	AVG( a.score ) DESC,
	a.C ASC

26.查询平均成绩大于等于 85 的所有学生的学号、姓名和平均成绩

SELECT
	a.S,
	a.Sname,
	AVG( b.score ) AS score_avg 
FROM
	student a
	INNER JOIN sc b ON a.S = b.S 
GROUP BY
	a.S 
HAVING
	score_avg >= 85

27. 查询课程名称为「数学」,且分数低于 60 的学生姓名和分数

SELECT
	a.Sname,
	b.score 
FROM
	sc b
	INNER JOIN course c ON b.C = c.C 
	AND c.Cname = '数学'
	INNER JOIN student a ON b.S = a.S 
WHERE
	b.score < 60

28. 查询所有学生的课程及分数情况(存在学生没成绩,没选课的情况)

SELECT
	a.S,
	a.Sname,
	IFNULL( b.C, '未选修' ) AS C,
	IFNULL( b.score, 0 ) AS score 
FROM
	student a
	LEFT JOIN sc b ON a.S = b.S

29. 查询任何一门课程成绩在 70 分以上的姓名、课程名称和分数

SELECT
	a.Sname,
	c.Cname,
	b.score 
FROM
	sc b
	LEFT JOIN student a ON b.S = a.S
	LEFT JOIN course c ON b.C = c.C 
WHERE
	b.score > 70;

30. 查询不及格的课程

SELECT DISTINCT
	b.C 
FROM
	sc b 
WHERE
	b.score < 60

31. 查询课程编号为 01 且课程成绩在 80 分以上的学生的学号和姓名

SELECT
	a.S,
	a.Sname 
FROM
	sc b
	LEFT JOIN student a ON b.S = a.S 
WHERE
	b.C = '01' 
	AND b.score > 80

32. 求每门课程的学生人数

SELECT
	b.C,
	COUNT( b.C ) AS c_count 
FROM
	sc b 
GROUP BY
	b.C

33. 成绩不重复,查询选修「张三」老师所授课程的学生中,成绩最高的学生信息及其成绩

SELECT
	a.S,
	a.Sname,
	a.Sage,
	a.Ssex,
	b.score 
FROM
	sc b
	LEFT JOIN student a ON b.S = a.S
	LEFT JOIN course c ON b.C = c.C
	INNER JOIN teacher t ON c.T = t.T 
	AND t.Tname = '张三' 
ORDER BY
	b.score DESC 
	LIMIT 1

34. 成绩有重复的情况下,查询选修「张三」老师所授课程的学生中,成绩最高的学生信息及其成绩

SELECT
	t.S,
	t.Sname,
	t.Sage,
	t.Ssex,
	t.score 
FROM
	(
	SELECT
		a.S,
		a.Sname,
		a.Sage,
		a.Ssex,
		b.score,
		dense_rank() over ( PARTITION BY b.C ORDER BY b.score DESC ) AS rk 
	FROM
		sc b
		LEFT JOIN student a ON b.S = a.S
		LEFT JOIN course c ON b.C = c.C
		INNER JOIN teacher t ON c.T = t.T 
		AND t.Tname = '张三' 
	) t 
WHERE
	t.rk = 1

35. 查询不同课程成绩相同的学生的学生编号、课程编号、学生成绩

SELECT
	b.S,
	b.C,
	b.score 
FROM
	sc b
	INNER JOIN sc d ON b.S = d.S 
	AND b.C <> d.C 
	AND b.score = d.score 
GROUP BY
	b.S,
	b.C

36. 查询每门功成绩最好的前两名

SELECT
	b.C,
	b.S,
	b.score 
FROM
	sc b
	LEFT JOIN sc d ON b.C = d.C 
	AND b.score < d.score 
GROUP BY
	b.S,
	b.C,
	b.score 
HAVING
	COUNT( 1 ) <= 1 
ORDER BY
	b.C

37. 统计每门课程的学生选修人数(超过 5 人的课程才统计)

SELECT
	b.C,
	COUNT( 1 ) AS c_count
FROM
	sc b 
GROUP BY
	b.C 
HAVING
	COUNT( 1 ) > 5

38. 检索至少选修两门课程的学生学号

SELECT
	b.S,
	COUNT( 1 ) AS c_count 
FROM
	sc b 
GROUP BY
	b.S 
HAVING
	COUNT( 1 ) >= 2

39. 查询选修了全部课程的学生信息

SELECT
	a.S,
	a.Sname,
	a.Sage,
	a.Ssex 
FROM
	sc b
	INNER JOIN student a ON a.S = b.S 
GROUP BY
	b.S 
HAVING
	count( b.C )=(
	SELECT
		count( 1 ) 
FROM
	course)

40. 查询各学生的年龄,只按年份来算

SELECT
	a.S,
	a.Sname,
	a.Ssex,
	YEAR (
	now())- YEAR ( a.Sage ) AS age 
FROM
	student a

41. 按照出生日期来算,当前月日 < 出生年月的月日则,年龄减一

SELECT
	a.S,
	a.Sname,
	a.Ssex,
	TIMESTAMPDIFF(
		YEAR,
		a.Sage,
	NOW()) AS 年龄 
FROM
	student a

42. 查询本周过生日的学生

SELECT
	a.S,
	a.Sname,
	a.Sage,
	a.Ssex,
	SUBSTR( YEARWEEK( a.Sage ), 5, 2 ) AS birth_week,
	SUBSTR( YEARWEEK( CURDATE()), 5, 2 ) AS now_week 
FROM
	student a 
WHERE
	SUBSTR( YEARWEEK( a.Sage ), 5, 2 ) = SUBSTR( YEARWEEK( CURDATE()), 5, 2 )

43. 查询下周过生日的学生

SELECT
	a.S,
	a.Sname,
	a.Sage,
	a.Ssex,
	SUBSTR( YEARWEEK( a.Sage ), 5, 2 ) AS birth_week,
	SUBSTR( YEARWEEK( CURDATE()), 5, 2 ) AS now_week 
FROM
	student a 
WHERE
	SUBSTR( YEARWEEK( a.Sage ), 5, 2 ) = SUBSTR( YEARWEEK( CURDATE()), 5, 2 )+1

44. 查询本月过生日的学生

SELECT
	* 
FROM
	student a 
WHERE
	EXTRACT( MONTH FROM a.Sage )= EXTRACT(
	MONTH 
FROM
	CURDATE());

45. 查询下月过生日的学生

SELECT
	* 
FROM
	student a 
WHERE
	EXTRACT( MONTH FROM a.Sage )= EXTRACT(
	MONTH 
FROM
	DATE_ADD( CURDATE(), INTERVAL 1 MONTH ));

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

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

相关文章

VXLAN基础介绍

VXLAN简介 VXLAN&#xff08;Virtual eXtensible Local Area Network&#xff0c;虚拟扩展局域网&#xff09;采用MAC in UDP封装方式&#xff0c;是NVO3&#xff08;Network Virtualization over Layer 3&#xff09;中的一种网络虚拟化技术。 VXLAN特性在本质上属于一种VPN技…

MySQl高可用集群搭建(MGR + ProxySQL + Keepalived)

前言 服务器规划&#xff08;CentOS7.x&#xff09; IP地址主机名部署角色192.168.x.101mysql01mysql192.168.x.102mysql02mysql192.168.x.103mysql03mysql192.168.x.104proxysql01proxysql、keepalived192.168.x.105proxysql02proxysql、keepalived 将安装包 mysql_cluster_…

这套软件测试试卷能打90分,直接入职字节吧

目录 一&#xff0e;填空 二、 判断题&#xff08;正确的√&#xff0c;错误的╳&#xff09;共10分&#xff0c;每小题1分 三、数据库部分&#xff1a;&#xff08;共15分&#xff09; 四、设计题。本题共 1 小题&#xff0c;满分 20分 一&#xff0e;填空 1、 系…

让ArcMap变得更加强大,用python执行地理处理以及编写自定义脚本工具箱

文章目录一、用python执行地理处理工具1.1 例&#xff1a;乘以0.00011.2 例&#xff1a;裁剪栅格1.3 哪里查看调用某工具的代码&#xff1f;二、用python批量执行地理处理工具2.1 必需的python语法知识for循环语句缩进的使用注释的使用2.2 一个批处理栅格的代码模板三、创建自定…

数组中的各种迭代API方法手写

js的数组上有很多实用的方法&#xff0c;不论是在遍历数组上&#xff0c;还是在操作数组内元素上&#xff0c;它有许多不同的遍历数组的方法&#xff0c;同时它还有着可以直接操作数组中间元素的方法。 接下来&#xff0c;我来带大家手写数组里的 遍历方法 。 Array.forEach(…

Elasticsearch在Linux中的单节点部署和集群部署

目录一、Elasticsearch简介二、Linux单节点部署1、软件下载解压2、创建用户3、修改配置文件4、切换到刚刚创建的用户启动软件5、测试三、Linux集群配置1、拷贝文件2、修改配置文件3、分别修改文件所有者4、启动三个软件5、测试四、问题总结1、在elasticsearch启动时如果报错内存…

【黑盒模糊测试】路由器固件漏洞挖掘实战--AFL++ qemu_mode

前言 很久之前就想写AFL++的qemu_mode了,只是模糊测试专题的文章有些过于耗费时间,加上工作原因导致一直搁置。最近需要出差会用到黑盒模糊测试,所以就当做复习一遍,我记得Fuzzing 101也有一个qemu_mode的练习,有空的话下一篇文章更新吧~ 编写不易,如果能够帮助到你,希望…

金三银四软件测试面试如何拿捏面试官?【接口测试篇】

九、接口测试 9.1 接口测试怎么测 &#xff08;jmeter版本&#xff09; 首先开发会给我们一个接口文档&#xff0c;我们根据开发给的接口文档&#xff0c;进行测试点的分析&#xff0c;主要是考虑正常场景与异常场景&#xff0c;正常场景&#xff0c;条件的组合&#xff0c;…

前端vue实现获取七天时间和星期几功能

前端vue实现获取七天时间和星期几功能 功能展示代码 <div v-for"(item,index) in same_week" :class"[same_dayitem.date? activ :,dis]" click"select(item)" :keyindex><span>{{item.name}}</span><span>{{item.…

[技术经理]01 程序员最优的成长之路是什么?

00前言 谈起程序员的职业规划&#xff0c;针对大部分的职场人士&#xff0c;最优的成长之路应该是走技术管理路线&#xff0c;而不是走技术专家路线。 01关键的一步 中国自古就有“学而优则仕”的传统&#xff0c;发展到今天&#xff0c;在我们的现代企业里面&#xff0c;尤…

【JavaEE初阶】第一节.多线程(进阶篇 ) 常见的锁策略、CAS及它的ABA问题

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 前言一、常见的锁策略 1.1 乐观锁 vs 悲观锁 1.2 普通的互斥锁 vs 读写锁 1.3 重量级锁 vs 轻量级锁 1.4 自旋锁 vs 挂起等待锁 1.5 公平…

Mac - Spotlight(聚焦)

文章目录一、Mac 中 Spotlight 的使用1、调用/打开 Spotlight2、执行搜索3、Spotlight 设置二、Mac 上的 Spotlight 开发1、关于 Spotlight2、使用 NSMetadataQuery 搜索示例三、mds 和 fsevents四、命令行访问 Spotlight五、Core Spotlight Framework六、Spotlight 插件相关资…

拼多多订单查询

下载地址webcrawl最新版本下载、安装、运行教程使用场景场景一我有很多个拼多多的买家号&#xff0c;想通过一个订单编号&#xff0c;查询该订单的各种信息&#xff0c;如订单状态&#xff0c;收件信息&#xff0c;物流信息&#xff0c;售后信息&#xff0c;联系商家场景二有很…

unix高级编程-fork和execve

fork和vfork vfork是老的实现方法又很多问题 vfork #include <sys/types.h> #include <unistd.h> #include <stdlib.h> #include <stdio.h> #include <string.h> #include <signal.h> #include <errno.h> #include <sys/stat.…

AQS-ReentrantLock

一、AQS 在 Lock 中&#xff0c;用到了一个同步队列 AQS&#xff0c;全称 AbstractQueuedSynchronizer&#xff0c;它是一个同步工具&#xff0c;也是 Lock 用来实现线程同步的核心组件。 1.AQS 的两种功能 独占和共享。 独占锁&#xff1a;每次只能有一个线程持有锁&#x…

Git 分支操作

1&#xff1a;什么是分支几乎所有的版本控制系统都以某种形式支持分支。 使用分支意味着你可以把你的工作从开发主线上分离 开来进行重大的Bug修改、开发新的功能&#xff0c;以免影响开发主线。 几乎所有的版本控制系统都以某种形式支持分支。 使用分支意味着你可以把你的工作…

2023“Java基础-中级-高级”面试集结,已奉上我的膝盖

Java基础&#xff08;对象线程字符接口变量异常方法&#xff09; 面向对象和面向过程的区别&#xff1f; Java 语言有哪些特点&#xff1f; 关于 JVM JDK 和 JRE 最详细通俗的解答 Oracle JDK 和 OpenJDK 的对比 Java 和 C的区别&#xff1f; 什么是 Java 程序的主类&…

GLOG如何控制输出的小数点位数

1 问题 在小白的蹩脚翻译演绎型博文《GLOG从入门到入门》中&#xff0c;有位热心读者提问说&#xff1a;在保存日志时&#xff0c;浮点型变量的小数位数如何设置&#xff1f; 首先感谢这位“嘻嘻哈哈的地球人”赏光阅读了小白这不太通顺的博客文章&#xff0c;并提出了一个很…

红旗语音助手HMI设计流程之调研篇

红旗智能语音助手是基于红旗4.0智能化平台打造的场景设计研究成果。本篇文章&#xff0c;将会以红旗语音助手为例&#xff0c;带领小伙伴们了解一下HMI设计中的调研工作。在项目中&#xff0c;我们需要要通过多模态的调研手段&#xff0c;去分辨用户的哪些需求是真需求&#xf…

【C++】string类的基本使用

层楼终究误少年&#xff0c;自由早晚乱余生。你我山前没相见&#xff0c;山后别相逢… 文章目录一、编码&#xff08;ascll、unicode字符集、常用的utf-8编码规则、GBK&#xff09;1.详谈各种编码规则2.汉字在不同的编码规则中所占字节数二、string类的基本使用1.string类的本质…