mysql 동영상 튜토리얼칼럼 소개실행 계획 설명
권장(무료): mysql 동영상 튜토리얼
목차
- 1
- 2. 결과를 설명하세요. 컬럼 자세한 설명
- 2.1 id
- 2.2 select_type
- 2.3 table
- 2.4 partitions
- 2.5 type(매우 중요)
- 2.6 available_keys
- 2.7 key
- 2.8 key_len
- 2.9 ref
- 3.10행
- 2.11filtered
- 2.12 Extra
【주의사항】
- 현재 시스템 환경 :
MySQL 5.7
, 그 외 버전은 약간 다르며, 추후 별도로 설명하겠습니다.MySQL 5.7
,其他版本略有不同,后期会抽时间单独说明。 - 只介绍常见的场景,其他少见的场景暂不研究,如有需要可以去官方文档中查找。
- 非入门,需要对
MySQL
的底层数据结构B+
树有一定的了解。
文档参考:
MySQL 官方 Explain 文档
1. 介绍
使用 EXPLAIN
关键字可以模拟优化器执行 SQL
语句,并分析查询语句的性能瓶颈。
2. Explain 结果列详解
2.1 id
-
id
列的编号是select
的序列号,一般有几个select
就有几个id
(联表查询会有重复的id
),并且id
的顺序是按select
出现的顺序增长的。 -
id
越大则表示执行的优先级越高,id
相同(一般出现在联表查询)则从上往下执行,id
为NULL
最后执行。
2.2 select_type
select_type
表示对应行是简单的还是复杂的查询。常见的值有:
simple
:简单查询,查询不包含子查询和union。primary
:复杂查询中最外层的 select 。subquery
:包含在 select 中的子查询(不在 from 子句中)derived
:包含在 form 子句中的子查询,MySQL 会将结果放在一个临时表中,也称为派生表。union
:在 union 中的第二个或之后的 select。
【注】在 MySQL 5.7
中,会对衍生表进行合并优化,如果要直观的查看 select_type
的值,需要临时关闭该功能(默认是打开的),下面的介绍中凡是涉及到衍生表的都需要该操作。
# 关闭衍生表的合并优化(只对该会话有效)set session optimizer_switch='derived_merge=off'; # 打开衍生表的合并优化(只对该会话有效)set session optimizer_switch='derived_merge=on';
2.3 table
对应行查询的表。
【注】
- 当
from 子句
中有子查询时,table 列为是<derivenn></derivenn>
的格式,表示这一行的执行的是id = N
行的查询。 - 当有
union
时,table 的数据为<union m></union>
的格式,M 和 N
表示参与union
的select
行id
。
2.4 partitions
未完待续。。。
2.5 type(非常重要)
-
type
表示这行查询的关联类型(访问类型,或查询类型),通过该值可以了解该行查询数据记录的大概范围。 - 常见的值依次从最优到最差分别为:
system > const > eq_ref > ref > range > index > ALL
;一般我们要保证效率的话,要优化我们的语句至少使其达到range
级别,如果可能的话做好优化到ref
;range
一般用于范围查找,所以换句话说除了范围查找,其他的查询语句我们最好是优化到ref
级别。
常见值说明:
NULL
: 表示MySQL
能够在优化阶段分解查询语句,在执行阶段不用访问表和索引。-
일반적인 시나리오만 소개합니다. 기타 희귀 시나리오는 당분간 연구하지 않습니다. 필요한 경우 공식 문서에서 찾을 수 있습니다. 🎜🎜초보자가 아닌,system / const
: MySQL 能对某个查询部分进行优化并将其转化成一个常量(可以通过show warnings
查看优化的结果),主要是查询主键(Primary Key
)或唯一键索引(Unique Key
)对应的记录,因为不存在重复,所以最多只能查询出一条记录,所以速度比较快。system
是const
的特例,当临时表里只有一条记录时为system
MySQL
의 기본 데이터 구조B+
트리에 대한 어느 정도 이해가 필요합니다. 🎜🎜🎜문서 참조:
🎜🎜1. 소개🎜🎜🎜
MySQL 공식 설명 문서🎜EXPLAIN
키워드를 사용하여의 최적화 실행을 시뮬레이션합니다. SQL
문을 사용하여 쿼리 문의 성능 병목 현상을 분석합니다. 🎜🎜🎜2. 결과 컬럼에 대한 자세한 설명을 설명해주세요🎜🎜🎜🎜2.1 id🎜🎜🎜🎜id
컬럼의 번호는select
의 일련번호이며, 일반적으로 여러 개의select
가 여러 개의id
를 갖고 있으며(공동 테이블 쿼리에는 중복된id
가 있음)id
의 순서가 있습니다. >는select
에 따라 오름차순으로 나타납니다. 🎜🎜id
가 클수록 실행 우선순위가 높아집니다.id
가 동일한 경우(일반적으로 공동 테이블 쿼리에 나타남) 위에서부터 실행됩니다. 하단.NULL
에 대해id가 마지막으로 실행됩니다. 🎜🎜🎜🎜2.2 select_type🎜🎜🎜<code>select_type
은 해당 행이 단순 쿼리인지 또는 복잡한 쿼리인지를 나타냅니다. 일반적인 값은 다음과 같습니다. 🎜🎜🎜🎜simple
: 단순 쿼리, 쿼리에 하위 쿼리 및 공용체는 포함되지 않습니다. 🎜🎜🎜🎜기본
: 복잡한 쿼리에서 가장 바깥쪽 선택입니다. 🎜🎜🎜🎜subquery
: select에 포함된 하위 쿼리(from 절에는 없음) 🎜🎜🎜🎜derived
: form 절에 포함된 하위 쿼리, MySQL은 결과를 임시 테이블에 배치합니다. , 파생 테이블이라고도 합니다. 🎜🎜🎜🎜union
: Union에서 두 번째 또는 후속 선택입니다. 🎜🎜🎜🎜【참고】MySQL 5.7
에서는 파생 테이블이 병합되어 최적화됩니다.select_type
값을 직관적으로 보려면 일시적으로 꺼야 합니다. 이 함수(기본값은 열려 있음), 🎜다음 소개에서 파생 테이블과 관련된 모든 것에는 이 작업이 필요합니다🎜. 🎜# 表里有一个主键id为1的记录 - constexplain select * from student where id = 1# 派生表里面只有一条记录 - systemexplain select * from (select * from student where id = 1) tmp# 注: 如果查询的列中有 text 类型,那么在这里 type 会变为 ALL ,# 因为无法使用内存临时表,只能在磁盘上创建临时表,所以性能上会有所损耗,效果等同于全表查询 ALL。
🎜🎜2.3 table🎜🎜🎜행 쿼리에 해당하는 테이블입니다. 🎜🎜【참고】🎜🎜🎜from 절
에 하위 쿼리가 있는 경우 테이블 열은<derivenn></derivenn>
형식으로 실행됩니다. 이 행 중id = N
인 행에 대한 쿼리입니다. 🎜🎜union
이 있는 경우 테이블 데이터는<union m></union>
형식이며,M과 N
은 참여를 나타냅니다.Union
의select
라인id
. 🎜🎜🎜🎜2.4 파티션🎜🎜🎜계속됩니다. . . 🎜🎜🎜2.5 유형(매우 중요) 🎜🎜🎜🎜type
은 이 쿼리 행의 관련 유형(액세스 유형 또는 쿼리 유형)을 나타냅니다. 이 값을 통해 대략적인 범위를 이해할 수 있습니다. 쿼리 데이터 레코드의 행. 🎜🎜일반적인 값은 다음과 같습니다.system > const > eq_ref > range > index > ALL
; 최소한range
수준에 도달하도록 문을 최적화하고, 가능하다면ref
로 최적화하세요. 일반적으로 범위 검색에 사용되므로 In을 변경하세요. 즉, 범위 검색 외에도 다른 쿼리 문을ref
수준으로 최적화하는 것이 좋습니다. 🎜🎜🎜🎜공통 값 설명🎜: 🎜🎜🎜🎜NULL
:MySQL
이 실행 단계에서 테이블과 인덱스에 액세스하지 않고 최적화 단계에서 쿼리 문을 분해할 수 있음을 나타냅니다. . 🎜🎜🎜🎜system / const
: MySQL은 특정 쿼리 부분을 최적화하고 이를 상수로 변환할 수 있습니다(최적화 결과는경고 표시
를 통해 볼 수 있음). 기본 키(기본 키
) 또는 고유 키 인덱스(고유 키
)에 해당하는 레코드를 쿼리하려면 중복이 없으므로 하나의 레코드만 쿼리할 수 있습니다. 대부분이라 속도가 상대적으로 빠릅니다.system
은const
의 특수한 경우로, 임시 테이블에 레코드가 하나만 있을 때system
입니다. 🎜# 表里有一个主键id为1的记录 - constexplain select * from student where id = 1# 派生表里面只有一条记录 - systemexplain select * from (select * from student where id = 1) tmp# 注: 如果查询的列中有 text 类型,那么在这里 type 会变为 ALL ,# 因为无法使用内存临时表,只能在磁盘上创建临时表,所以性能上会有所损耗,效果等同于全表查询 ALL。
-
req_ref
:当主键或唯一键索引的相关列并联接使用时(联表查询),最多匹配一条符合条件的记录。这是除了const
之外的最好的联接类型,简单的select
查询不会出现req_ref
,更多出现在联表查询。# 虽然返回结果中有多条记录,但是在查询中一个学生id只对应一个班级,所以查询班级的时候为 req_ref,# 但是查询 student 的时候是 ALL,全表查询explain select * from student left join banji on student.id = banji.student_id
【注】在查询的过程中的返回结果如下:
当联接表查询时候会看作是一条查询 SQL
,所以它们对应的 id
是一样的,当 id
都是一样的时候,按照从上到下
的顺序依次执行,这里是先查询班级所有的学生(全表查询 ALL
),然后根据学生id
查找出学生对应的班级信息(req_ref
)。
-
ref
:当使用普通索引(Normal)
或者是联合索引的部分前缀
时,索引要和某个值进行比较,可能会找到多个符合条件的记录行,从辅助索引的根节点开始对比并找到相应的记录。# 简单的 select 查询,name 是普通索引(Normal Index)explain select * from student where name = '张三';# 简单 select 查询,banji_id (第一个) 和 student_id (第二个) 的联合索引EXPLAIN SELECT * FROM banji_student WHERE banji_student.banji_id = 3# 关联表查询# 包含 banji 表,banji_student 是班级与学生的关系表# 关系表中有 banji_id (第一个) 和 student_id (第二个) 的联合索引 idx_banji_stu_id 索引,# 以下查询只用到了联合索引的 banji_id (第一个)explain select * from banji_id from banji left join banji_student on banji.id = banji_student.banji_id
-
range
:范围扫描,通常出现在in,between,>,=
等操作中,使用一个索引来检索给定范围的行。# 查询 id 大于 1 的学生信息explain select * from student where id > 2;
-
index
:- 扫描全索引就能拿到结果,一般是扫描某个
二级索引
(辅助索引,除了主键之外的索引
)。这种索引不会从主键索引树根节点开始查找,而是直接对二级索引的叶子节点遍历和扫描,从而查找出相应的记录行,速度比较慢; - 这种查询方式一般为使用
覆盖索引
,查询所需的所有结果集在二级索引
与主键索引
中都有的情况下,由于二级索引
一般比较小(因为二级索引
是非聚集
的,其叶子节点是存放的主键索引
相应的地址,而主键索引
是聚集的,其叶子节点存放的是完整的数据集),所以优先走二级索引,这种情况通常比ALL
快一些。 - 在某些情况下,如果表的列数特别多,这个时候通过
辅助索引
查询的性能就不如直接使用主键索引
效率高(如果查询了辅助索引
的话,还会返回到主键索引中进行查找更多的字段,也就是回表查询
,当然在某些情况下使用回表查询
的性能也会比只使用主键索引
的性能高),这个时候会走主键索引,这种情况也比ALL
快。
# student 表只有id主键,name 普通索引select * from student;# 这个时候会走 name 索引# 因为 name 是普通索引,所以如果加 where 的话可以达到 ref 级别select * from student where name = 'Ana'
覆盖索引
定义:覆盖索引一般针对于辅助索引,并不是真正的索引,只是索引查找的一种方式。如果select
查询的字段都在辅助索引树中全部拿到,这种情况一般是使用了覆盖索引
,不需要通过辅助索引树
找到主键
,再通过主键
去主键索引树
里获取其它字段值。 - 扫描全索引就能拿到结果,一般是扫描某个
-
ALL
:全表扫描,扫描主键(聚簇、聚集)索引树的所有叶子节点,通常这种情况下要根据业务场景来增加其他索引进行优化。# id 为主键的 student 表,没有其他索引,该查询为 ALL.select * from student
2.6 possible_keys
possible_keys
主要显示查询可能用到哪些索引来查找,只是可能会使用,并不代表一定会使用。
常见值说明:
-
NULL
: 没有相关索引,如果是NULL
的话,可以考虑在where 子句
中创建一个适当的索引来提高查询性能,然后继续用explain
查看其效果;也有可能出现possible_keys
为NULL
,但是key
有值,实际走了索引。 - 有列值:如果显示表中的某列,则表示可能会走这一列对应列值的索引;如果
possible_keys
有值,但是key
显示NULL
,这种情况一般存在于表中数据量不大的情况,因为MySQL
语句优化器认为索引对此查询的帮助不大,从而选择了全表查询
。
2.7 key
-
key
表示MySQL
实际采用哪个索引来优化对该表的查询。 - 如果没有使用索引,则该列为
NULL
,如果想强制MySQL
使用或忽略possible_keys
列中的索引,可以在查询中使用force index
或ignore index
.
2.8 key_len
显示了 MySQL
索引所使用的字节数
,通过这个数值可以计算具体使用了索引中的哪些列(主要用于联合索引的优化)。
【注】索引最大长度是 768 字节
,当字符串过长时,MySQL
会做一个类似左前缀索引的处理,将前半部分的字符提取出来做索引。
示例:一个学生与班级的关系表:
banji_student
,存在使用banji_id
与student_id
两个列组合的联合索引,并且每个索引int
都是4
字节,通过key_len
值为4
可以知道只使用了联合索引的第一列:banji_id
来执行索引查找。
# 只使用了联合索引的第一列select * from banji_student where banji_id = 2
key_len
的计算规则如下:
-
字符串:常见的是
char(n)
和varchar(n)
,从MySQL 5.0.3
之后,n
均表示字符数
,而不是字节数
,如果是UTF-8
,一个数字或字母占1
个字节,一个汉字占3
个字节。描述 char(n)
非汉字长度为 n
,如果存放汉字长度为3n
字节varchar(n)
非汉字长度为 n+2
,如果存放汉字长度为3n+2
字节;因为varchar
是可变长字符串,需要2
字节来存储字符串长度 -
数值类型:
描述 tinyint
长度为 1
字节smallint
长度为 2
字节int
长度为 4
字节bigint
长度为 8
字节 -
时间类型:
描述 date
长度为 3
字节timestamp
长度为 4
字节datetime
长度为 8
字节 -
NULL
如果字段允许设置为
NULL
,则需要1
字节来记录是否为NULL
;Not NULL
的列则不需要。
2.9 ref
显示了在使用 key
列中实际的索引时,表查找时所用到的列名和常量;常见的为 const
常量或索引关联查询的字段(列)名
。
# 使用了常量 2,所以在查询的时候 ref 为 constselect * from student where id = 2# 关联表查询# 包含 banji 表,banji_student 是班级与学生的关系表# 关系表中有 banji_id (第一个) 和 student_id (第二个) 的联合索引 idx_banji_stu_id 索引# 这里的 ref 为 test.id ,也就是指的是 banji.idexplain select * from banji_id from banji left join banji_student on banji.id = banji_student.banji_id
3.10 rows
显示预计查询的结果数,并不是真正的结果集中的记录(行)数,仅供参考。
2.11 filtered
未完待续。。。
2.12 Extra
这一列展示的是额外的信息,存在很多值,且在不同的场景下以及不同版本的 MySQL
所表示的意思也不同,只能是表示大概的意思并且仅做优化参考,这里只介绍常见的值。
-
Using index
:使用覆盖索引,在type
相同的情况下,Extra
的值为Using index
要比为NULL
性能高。比如
banji
表,存在id,name,create_time
列,存在id 主键
与name 普通索引
。# 覆盖索引,直接查询 name 对应的索引树就可以满足 select 后面的查询列select id,name from banji# 非覆盖索引,虽然也走了索引,但是进行了回表查询,以查询出 create_time 字段。select * from banji where name = '二年级'
-
Using where
:使用where
关键字来查询,并且对应的列没有设置索引,对应的key
为NULL
。这种情况一般要对查询的列添加相对应的索引来进行优化。
-
Using index condition
:非覆盖索引查询并进行了回表,并且辅助索引使用了条件查询语句(where
或其他)。比如
banji_student
关系表,存在id,banji_id,student_id,create_time
列,存在id 主键
和banji_id 与 student_id 的组合(联合)索引
。# 进行了回表查询,以查询出 create_time 列,并且组合索引进行了范围查找select * from banji_student where banji_id > 3
-
Using temporary
:MySQL
需要创建创建一个临时表来处理查询,出现这种情况一般要添加索引进行优化处理。# 如果 name 没有添加普通索引的话,则需要创建一个临时表来进行去重,Extra 值为 Using temporary# 如果添加了索引,则会走 name 对应的索引树,并且是覆盖索引,Extra 值为 Using indexexplain select distinct name from student
-
Using filesort
:使用外部排序而不是索引排序,当数据较小的时候采用的是内存排序,当数据量较大的时候会频繁的访问磁盘,并将排序后的数据写入磁盘。# 如果 name 没有添加普通索引的话,则需要创建一个临时表来进行去重,Extra 值为 Using filesort# 如果添加了索引,则会走 name 对应的索引树,并且是覆盖索引,Extra 值为 Using indexexplain select name from student order by name
-
Select tables optimized away
:使用聚合函数
(例如max
、min
等)来访问存在索引的字段时,只访问索引树中已排好序的叶子,节点性能很高。# 比如使用聚合函数 min 查询最小的学生 id(主键)explain select min(id) from student
위 내용은 MySQL 5.7 최적화에 대한 자세한 설명: 실행 계획 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

MySQL은 오픈 소스 관계형 데이터베이스 관리 시스템으로, 주로 데이터를 신속하고 안정적으로 저장하고 검색하는 데 사용됩니다. 작업 원칙에는 클라이언트 요청, 쿼리 해상도, 쿼리 실행 및 반환 결과가 포함됩니다. 사용의 예로는 테이블 작성, 데이터 삽입 및 쿼리 및 조인 작업과 같은 고급 기능이 포함됩니다. 일반적인 오류에는 SQL 구문, 데이터 유형 및 권한이 포함되며 최적화 제안에는 인덱스 사용, 최적화 된 쿼리 및 테이블 분할이 포함됩니다.

MySQL은 데이터 저장, 관리, 쿼리 및 보안에 적합한 오픈 소스 관계형 데이터베이스 관리 시스템입니다. 1. 다양한 운영 체제를 지원하며 웹 응용 프로그램 및 기타 필드에서 널리 사용됩니다. 2. 클라이언트-서버 아키텍처 및 다양한 스토리지 엔진을 통해 MySQL은 데이터를 효율적으로 처리합니다. 3. 기본 사용에는 데이터베이스 및 테이블 작성, 데이터 삽입, 쿼리 및 업데이트가 포함됩니다. 4. 고급 사용에는 복잡한 쿼리 및 저장 프로 시저가 포함됩니다. 5. 설명 진술을 통해 일반적인 오류를 디버깅 할 수 있습니다. 6. 성능 최적화에는 인덱스의 합리적인 사용 및 최적화 된 쿼리 문이 포함됩니다.

MySQL은 성능, 신뢰성, 사용 편의성 및 커뮤니티 지원을 위해 선택됩니다. 1.MYSQL은 효율적인 데이터 저장 및 검색 기능을 제공하여 여러 데이터 유형 및 고급 쿼리 작업을 지원합니다. 2. 고객-서버 아키텍처 및 다중 스토리지 엔진을 채택하여 트랜잭션 및 쿼리 최적화를 지원합니다. 3. 사용하기 쉽고 다양한 운영 체제 및 프로그래밍 언어를 지원합니다. 4. 강력한 지역 사회 지원을 받고 풍부한 자원과 솔루션을 제공합니다.

InnoDB의 잠금 장치에는 공유 잠금 장치, 독점 잠금, 의도 잠금 장치, 레코드 잠금, 갭 잠금 및 다음 키 잠금 장치가 포함됩니다. 1. 공유 잠금을 사용하면 다른 트랜잭션을 읽지 않고 트랜잭션이 데이터를 읽을 수 있습니다. 2. 독점 잠금은 다른 트랜잭션이 데이터를 읽고 수정하는 것을 방지합니다. 3. 의도 잠금은 잠금 효율을 최적화합니다. 4. 레코드 잠금 잠금 인덱스 레코드. 5. 갭 잠금 잠금 장치 색인 기록 간격. 6. 다음 키 잠금은 데이터 일관성을 보장하기 위해 레코드 잠금과 갭 잠금의 조합입니다.

MySQL 쿼리 성능이 좋지 않은 주된 이유는 인덱스 사용, 쿼리 최적화에 의한 잘못된 실행 계획 선택, 불합리한 테이블 디자인, 과도한 데이터 볼륨 및 잠금 경쟁이 포함됩니다. 1. 색인이 느리게 쿼리를 일으키지 않으며 인덱스를 추가하면 성능이 크게 향상 될 수 있습니다. 2. 설명 명령을 사용하여 쿼리 계획을 분석하고 Optimizer 오류를 찾으십시오. 3. 테이블 구조를 재구성하고 결합 조건을 최적화하면 테이블 설계 문제가 향상 될 수 있습니다. 4. 데이터 볼륨이 크면 분할 및 테이블 디비전 전략이 채택됩니다. 5. 높은 동시성 환경에서 거래 및 잠금 전략을 최적화하면 잠금 경쟁이 줄어들 수 있습니다.

데이터베이스 최적화에서 쿼리 요구 사항에 따라 인덱싱 전략을 선택해야합니다. 1. 쿼리에 여러 열이 포함되고 조건 순서가 수정되면 복합 인덱스를 사용하십시오. 2. 쿼리에 여러 열이 포함되어 있지만 조건 순서가 고정되지 않은 경우 여러 단일 열 인덱스를 사용하십시오. 복합 인덱스는 다중 열 쿼리를 최적화하는 데 적합한 반면 단일 열 인덱스는 단일 열 쿼리에 적합합니다.

MySQL 느린 쿼리를 최적화하려면 SlowQueryLog 및 Performance_Schema를 사용해야합니다. 1. SlowQueryLog 및 Set Stresholds를 사용하여 느린 쿼리를 기록합니다. 2. Performance_schema를 사용하여 쿼리 실행 세부 정보를 분석하고 성능 병목 현상을 찾고 최적화하십시오.

MySQL 및 SQL은 개발자에게 필수적인 기술입니다. 1.MySQL은 오픈 소스 관계형 데이터베이스 관리 시스템이며 SQL은 데이터베이스를 관리하고 작동하는 데 사용되는 표준 언어입니다. 2.MYSQL은 효율적인 데이터 저장 및 검색 기능을 통해 여러 스토리지 엔진을 지원하며 SQL은 간단한 문을 통해 복잡한 데이터 작업을 완료합니다. 3. 사용의 예에는 기본 쿼리 및 조건 별 필터링 및 정렬과 같은 고급 쿼리가 포함됩니다. 4. 일반적인 오류에는 구문 오류 및 성능 문제가 포함되며 SQL 문을 확인하고 설명 명령을 사용하여 최적화 할 수 있습니다. 5. 성능 최적화 기술에는 인덱스 사용, 전체 테이블 스캔 피하기, 조인 작업 최적화 및 코드 가독성 향상이 포함됩니다.


핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

mPDF
mPDF는 UTF-8로 인코딩된 HTML에서 PDF 파일을 생성할 수 있는 PHP 라이브러리입니다. 원저자인 Ian Back은 자신의 웹 사이트에서 "즉시" PDF 파일을 출력하고 다양한 언어를 처리하기 위해 mPDF를 작성했습니다. HTML2FPDF와 같은 원본 스크립트보다 유니코드 글꼴을 사용할 때 속도가 느리고 더 큰 파일을 생성하지만 CSS 스타일 등을 지원하고 많은 개선 사항이 있습니다. RTL(아랍어, 히브리어), CJK(중국어, 일본어, 한국어)를 포함한 거의 모든 언어를 지원합니다. 중첩된 블록 수준 요소(예: P, DIV)를 지원합니다.

DVWA
DVWA(Damn Vulnerable Web App)는 매우 취약한 PHP/MySQL 웹 애플리케이션입니다. 주요 목표는 보안 전문가가 법적 환경에서 자신의 기술과 도구를 테스트하고, 웹 개발자가 웹 응용 프로그램 보안 프로세스를 더 잘 이해할 수 있도록 돕고, 교사/학생이 교실 환경 웹 응용 프로그램에서 가르치고 배울 수 있도록 돕는 것입니다. 보안. DVWA의 목표는 다양한 난이도의 간단하고 간단한 인터페이스를 통해 가장 일반적인 웹 취약점 중 일부를 연습하는 것입니다. 이 소프트웨어는

SecList
SecLists는 최고의 보안 테스터의 동반자입니다. 보안 평가 시 자주 사용되는 다양한 유형의 목록을 한 곳에 모아 놓은 것입니다. SecLists는 보안 테스터에게 필요할 수 있는 모든 목록을 편리하게 제공하여 보안 테스트를 더욱 효율적이고 생산적으로 만드는 데 도움이 됩니다. 목록 유형에는 사용자 이름, 비밀번호, URL, 퍼징 페이로드, 민감한 데이터 패턴, 웹 셸 등이 포함됩니다. 테스터는 이 저장소를 새로운 테스트 시스템으로 간단히 가져올 수 있으며 필요한 모든 유형의 목록에 액세스할 수 있습니다.

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

MinGW - Windows용 미니멀리스트 GNU
이 프로젝트는 osdn.net/projects/mingw로 마이그레이션되는 중입니다. 계속해서 그곳에서 우리를 팔로우할 수 있습니다. MinGW: GCC(GNU Compiler Collection)의 기본 Windows 포트로, 기본 Windows 애플리케이션을 구축하기 위한 무료 배포 가능 가져오기 라이브러리 및 헤더 파일로 C99 기능을 지원하는 MSVC 런타임에 대한 확장이 포함되어 있습니다. 모든 MinGW 소프트웨어는 64비트 Windows 플랫폼에서 실행될 수 있습니다.
