찾다
데이터 베이스MySQL 튜토리얼小贝_mysql优化学习_MySQL

mysql优化

简要:
1、数据库设计优化
2、sql语句优化
3、表分割
4、读写分离技术

 

一、数据库设计优化

1、表设计要符合三范式,当然,有时也需要适当的逆范式

2、什么是三范式

一范式: 具有原子性,不可再分割

二范式: 在满足一范式的基础上,我们考虑是否满足二范式。只要表的记录满足唯一性,也是说,同一张表,不可能出现完全相同的记录,一般说,在表中设计一个主键即可。

三范式: 在满足二范式的基础上,我们考虑是否满足三范式。只要表满足没冗余性。

 

二、SQL语句优化

1、sql优化的一般步骤

a、通过show status命令了解各种sql的执行效率

b、定位执行效率较低的sql语句

c、通过explain/desc分析低效率的sql语句的执行情况

d、确定问题并采取相应的优化措施

2、showstatus命令

该命令可以显示mysql数据库当前状态,主要关心的是’com’开头的指令

showstatus like ‘com%’ ó show session status like ‘com%’//显示当前控制台的情况

showglobal status like ‘com%’ //显示数据库从启动到现在的情况

3、showvariables命令

该命令可以查看mysql当前的变量设置,主要关心的是慢查询时间

 

\

4、如何在mysql中找到慢查询的sql语句

(备注: mysql数据库支持把慢查询语句,记录到日志中给程序员分析;默认情况下,mysql不启用慢查询日志)

步骤: a、启动mysql慢查询

a1、在启动mysql服务时,指定—slow-query-log

a2、在利用客户端登进mysql后,设置变量

\

 

b、查看慢查询时间

\默认为10秒

c、修改慢查询时间

\设置为1秒

(这个只能在当前环境生效,如果想每次都生效,就修改mysql的配置文件)

d、查看慢查询日志

\

 

e、根据慢查询的sql语句,进行优化。最廉价的做法就是加索引

 

\

f、加上索引后

 

\

5、索引的影响

a、增加磁盘空间

\

 

b、给增删改带来不便

6、哪些列上适合添加索引

a、频繁地作为查询条件字段应该创建索引

b、唯一性太差的字段(即该字段的值变化不大)不适合单独创建索引,即使频繁作为查询条件

c、更新非常频繁的字段不适合创建索引

d、不会出现在where子句中字段也不应该创建索引

7、索引的使用

测试表:

Create Table: CREATE TABLE`t2` (

`id` int(11) NOT NULL DEFAULT '0',

`name` char(5) DEFAULT NULL,

`age` tinyint(4) DEFAULT NULL,

PRIMARY KEY (`id`)

) ENGINE=MyISAM DEFAULTCHARSET=utf8;

insert into t2(name,age) values('a',2),('aa',3),('b',4),('c',3);

查询要使用索引最重要的条件是查询条件中需要使用索引。

下列几种情况下有可能使用到索引:

a、对于创建的多列索引,只要查询条件使用了最左边的列,索引一般就会被使用。

 

\
b、对于使用like的查询,查询如果是 ‘%aaa’不会使用到索引‘aaa%’ 会使用到索引。

\

 

下列的表将不使用索引:

a、如果条件中有or,即使其中有条件带索引也不会使用。

\
b、对于多列索引,不是使用的第一部分,则不会使用索引。
c、like查询是以%开头
d、如果列类型是字符串,那一定要在条件中将数据使用引号引用起来。否则不使用索引。
e、如果mysql估计使用全表扫描要比使用索引快,则不使用索引。

8、验证索引使用情况

showstatus like ‘Handler_read%’;

\

备注:
handler_read_key:这个值越高越好,越高表示使用索引查询到的次数。

handler_read_rnd_next:这个值越高,说明查询低效。

 

9、常用SQL优化

a、大批量插入数据:

对于MyIsam:

1、alter table table_name disable keys;

2、loading data;

3、alter table table_name enable keys;

对于Innodb:

1、将要导入的数据按照主键排序

2、set unique_checks=0,关闭 唯一性校验

3、set autocommit=0,关闭自动提交

(提示: myisam和innodb的区别是:

a、myisam不支持外接,innodb支持

b、myisam不支持事务,innodb支持)

b、优化group by

默认情况下,mysql对group by后面的列名进行排序。如果查询中包括group by但用户想要避免排序结果的消耗,可以使用order by null禁止排序

 

三、表分割

当一个表的数据很大的时候,其它的优化方式已经都考虑进去。起到的作用不大时,就要考虑分表了。即把一张大表分割成多张小表。

分表方式:

a、垂直分表

此时,表中存在很多列,这个时候可以通过主键,把表中列分成多张表,然后再根据主键进行关联.(拆分后,每张表的列都不同)

分表前: 个人信息表

id

name

age

email

intro

1

a

11

11@qq.com

xxxx

2

b

22

22@qq.com

yyyy

 

 

 

 

 

 

分表后: 个人信息表

id

name

age

email

1

a

11

11@qq.com

2

b

22

22@qq.com

个人介绍表

id

intro

1

xxxx

2

yyyy

 

b、水平分表

可以通过取模的方式,进行分表。因此,需要判断分成几张小表,即模的值为多少。另外,拆分后,每张表的列都是一致的。

分表前: 个人信息表

id

name

age

email

intro

1

a

11

11@qq.com

xxxx

2

b

22

22@qq.com

yyyy

 

 

 

 

 

确定取模的值为2,因此可以把这种表分为两张小表

1、判断id的值,id/2=?

分表后: 个人信息表0

id

name

age

email

intro

1

a

11

11@qq.com

xxxx

个人信息表1

id

name

age

email

intro

2

b

22

22@qq.com

yyyy

 

 

四、读写分离

通常来说,一台mysql服务器承载着所有关于数据库的操作。但是在访问量大的时候,mysql服务器很容易出现瓶颈。为了减少mysql服务器的压力,(mysql本身支持主从复制功能)

可以通过分离读写操作。

1、读写分离前示意图

\

2、读写分离

\

성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
MySQL에서 느린 쿼리를 식별하고 최적화하는 방법은 무엇입니까? (느린 쿼리 로그, Performance_schema)MySQL에서 느린 쿼리를 식별하고 최적화하는 방법은 무엇입니까? (느린 쿼리 로그, Performance_schema)Apr 10, 2025 am 09:36 AM

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

MySQL 및 SQL : 개발자를위한 필수 기술MySQL 및 SQL : 개발자를위한 필수 기술Apr 10, 2025 am 09:30 AM

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

MySQL 비동기 마스터 슬레이브 복제 프로세스를 설명하십시오.MySQL 비동기 마스터 슬레이브 복제 프로세스를 설명하십시오.Apr 10, 2025 am 09:30 AM

MySQL 비동기 마스터 슬레이브 복제는 Binlog를 통한 데이터 동기화를 가능하게하여 읽기 성능 및 고 가용성을 향상시킵니다. 1) 마스터 서버 레코드는 Binlog로 변경됩니다. 2) 슬레이브 서버는 I/O 스레드를 통해 Binlog를 읽습니다. 3) 서버 SQL 스레드는 데이터를 동기화하기 위해 Binlog를 적용합니다.

MySQL : 쉽게 학습하기위한 간단한 개념MySQL : 쉽게 학습하기위한 간단한 개념Apr 10, 2025 am 09:29 AM

MySQL은 오픈 소스 관계형 데이터베이스 관리 시스템입니다. 1) 데이터베이스 및 테이블 작성 : CreateAbase 및 CreateTable 명령을 사용하십시오. 2) 기본 작업 : 삽입, 업데이트, 삭제 및 선택. 3) 고급 운영 : 가입, 하위 쿼리 및 거래 처리. 4) 디버깅 기술 : 확인, 데이터 유형 및 권한을 확인하십시오. 5) 최적화 제안 : 인덱스 사용, 선택을 피하고 거래를 사용하십시오.

MySQL : 데이터베이스에 대한 사용자 친화적 인 소개MySQL : 데이터베이스에 대한 사용자 친화적 인 소개Apr 10, 2025 am 09:27 AM

MySQL의 설치 및 기본 작업에는 다음이 포함됩니다. 1. MySQL 다운로드 및 설치, 루트 사용자 비밀번호를 설정하십시오. 2. SQL 명령을 사용하여 CreateAbase 및 CreateTable과 같은 데이터베이스 및 테이블을 만듭니다. 3. CRUD 작업을 실행하고 삽입, 선택, 업데이트, 명령을 삭제합니다. 4. 성능을 최적화하고 복잡한 논리를 구현하기 위해 인덱스 및 저장 절차를 생성합니다. 이 단계를 사용하면 MySQL 데이터베이스를 처음부터 구축하고 관리 할 수 ​​있습니다.

InnoDB 버퍼 풀은 어떻게 작동하며 성능에 중요한 이유는 무엇입니까?InnoDB 버퍼 풀은 어떻게 작동하며 성능에 중요한 이유는 무엇입니까?Apr 09, 2025 am 12:12 AM

innodbbufferpool은 데이터와 색인 페이지를 메모리에로드하여 MySQL 데이터베이스의 성능을 향상시킵니다. 1) 데이터 페이지가 버퍼 풀에로드되어 디스크 I/O를 줄입니다. 2) 더러운 페이지는 정기적으로 디스크로 표시되고 새로 고침됩니다. 3) LRU 알고리즘 관리 데이터 페이지 제거. 4) 읽기 메커니즘은 가능한 데이터 페이지를 미리로드합니다.

MySQL : 초보자를위한 데이터 관리의 용이성MySQL : 초보자를위한 데이터 관리의 용이성Apr 09, 2025 am 12:07 AM

MySQL은 설치가 간단하고 강력하며 데이터를 쉽게 관리하기 쉽기 때문에 초보자에게 적합합니다. 1. 다양한 운영 체제에 적합한 간단한 설치 및 구성. 2. 데이터베이스 및 테이블 작성, 삽입, 쿼리, 업데이트 및 삭제와 같은 기본 작업을 지원합니다. 3. 조인 작업 및 하위 쿼리와 같은 고급 기능을 제공합니다. 4. 인덱싱, 쿼리 최적화 및 테이블 파티셔닝을 통해 성능을 향상시킬 수 있습니다. 5. 데이터 보안 및 일관성을 보장하기위한 지원 백업, 복구 및 보안 조치.

MySQL에서 인덱스를 사용하는 것보다 전체 테이블 스캔이 더 빠를 수 있습니까?MySQL에서 인덱스를 사용하는 것보다 전체 테이블 스캔이 더 빠를 수 있습니까?Apr 09, 2025 am 12:05 AM

전체 테이블 스캔은 MySQL에서 인덱스를 사용하는 것보다 빠를 수 있습니다. 특정 사례는 다음과 같습니다. 1) 데이터 볼륨은 작습니다. 2) 쿼리가 많은 양의 데이터를 반환 할 때; 3) 인덱스 열이 매우 선택적이지 않은 경우; 4) 복잡한 쿼리시. 쿼리 계획을 분석하고 인덱스 최적화, 과도한 인덱스를 피하고 정기적으로 테이블을 유지 관리하면 실제 응용 프로그램에서 최상의 선택을 할 수 있습니다.

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

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

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
WWE 2K25 : Myrise에서 모든 것을 잠금 해제하는 방법
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

ZendStudio 13.5.1 맥

ZendStudio 13.5.1 맥

강력한 PHP 통합 개발 환경

VSCode Windows 64비트 다운로드

VSCode Windows 64비트 다운로드

Microsoft에서 출시한 강력한 무료 IDE 편집기

mPDF

mPDF

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

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경