데이터 베이스 MySQL 튜토리얼 mysql数据库优化语句_MySQL

mysql数据库优化语句_MySQL

Jun 01, 2016 pm 01:41 PM
mysql 데이터베이스 최적화 언어

bitsCN.com mysql数据库优化语句 数据库语句:
     Ddl(数据定义语言)    alter  create   drop       Dml(数据操作语言)   inset  delete  update         Dtl(数据事务语言)  conmmit  rollback   savepoint     Select     Dcl(数据控制语句) grant赋权限  revoke回收   Mysql数据库优化:
 1、  数据库表 要设计合理(符合3NF,有时候也需要适当的逆范式)2、  Sql语句的优化(索引,常用小技巧)3、  数据库的配置4、  适当的硬件配置和操作系统5、  读写分离   问:什么是数据库3范式?    1NF: 就是具有原子性,不可分割(只要使用的是关系型数据库,就会自动符合)   2NF: 在满足1NF的基础上,我们考虑是否满足2NF,只要表的记录满足唯一性,也就是说,你的同一张表中不可能出现完全相同的记录,一般说我们在表中设计一个主键即可。   3NF: 在满足2NF: 的基础上,我们考虑是否满足3NF,既我们的字段信息可以通过关联的关系,派生即可(通常我们通过外键来处理)使用外键数据库的存储引擎必须是innoDB 问2:数据库参数配置      对于innodb存储引擎最重要的就是内存,所以下面的两个参数调的很大          Innodb_additional_mem_pool_size = 64M                Innodb_buffer_pool_size = 1G     缓冲池大小     对于myisam,需要调整key_buffer_size           用show  status 语句可以看到当前状态,以决定调整那些参数            一、显示你使用过多少次insert  , update   ,  delete 等Sql:    show status  like  “Com”;              //在命令窗口中不关闭的时候查询会准确,如果关闭就会从新开始统计              Show sessionstatus like “Com_update”;              //就算关闭窗口也会将全部的你执行过的次数统计出来              Show globalstatus like “Com_insert”; Example:  session                        假如已经使用了6次update1、  用session统计 会是6次如果关闭后命令窗口后在执行Show session statuslike “Com_update”;  就为0了2、  但是如果用Show global status like “Com_insert”;就是6次 二、显示试图连接Mysql服务器的次数              Show  status like  “Connections”;     数据库启动多长时间了              Show  status like   “uptime”;             显示慢查询多少次(默认是10秒)              Show  status like  “Slow_queries”; 四、如何在一个项目中,找到慢查询的select,mysql数据库支持把慢查询的语句记录到日志中,供程序员来分析           步骤:1、 启动mysql(特殊的启动方式)a)        在mysql的安装目录下的bin目录下启动mysqld.exe –slow-queryb)       Netstat –an 查看3306端口是否启动c)        查询慢查询的次数   show status  like  “Slow_queries”;d)       设置慢查询的时间   set long_query_time=1;    索引优化: 比如说增加主键索引              Alter  table user   add  primary key(id); 删除主键索引              Alter  table user  drop  primary key删除索引       Alter  table  user drop  index   索引名显示索引        Show  index(es)  from  表名         Show  keys  from  表名         Desc  表名   增加索引致使查询会变快好多,其原理就像一本书如果没有目录的话那么如果你想找一个知识点会很难找到,只能一点一点的翻着找,如果有目录的话会很快的定位到这个知识点在那个章节中大概什么位置这样查询起来自然就会快了啊,但是有利必有弊,索引会对查询带来好处,但是对add   update   delete  来说自然就很麻烦了,比如说你添加一个知识点,你不许还有在目录中添加他是属于那章那节中的那个知识点,同样在修改和删除的时候也会随之改变,来保持信息的准确性。       
mysql数据库优化语句_MySQL                                                                                                                  一个自动分析是否需要使用索引的命令:explainExample:  explain  select  *  from emp   where   id  =   9;
mysql数据库优化语句_MySQL
 索引的分类:         主键索引(primary   key)         唯一键索引(unique)         Index(普通索引)         全文索引(fulltext)         复合索引(多列和在一起)     在那些列上添加索引比较合适:1、比较频繁的作为查询条件的字段应该加上索引2、  唯一性比较差的字段不适合单独创建索引,及时频繁作为查询条件3、  更新非常频繁的字段不适合创建索引4、  不会出现在where子句中的字段不该创建索引 查询一个表中的所有索引: show  indexes   from  table(表名)                        索引的使用:             查询要使用索引最重要的条件是查询条件中需要使用索引             以下几种情况可能会使用到索引1、  对于创建的多列索引,只要查询条件使用了最左边的列,索引一般就会被使用2、  对于使用like的查询,查询如果是‘%aaa’不会使用到索引‘aaa%’会使用到索引             以下的表中将不使用索引1、  如果条件中有or,即使其中有条件带索引也不会使用2、  对于多列索引,不是使用的第一部分,则不会使用索引3、  Like查询是以%开头4、  如果列类型是字符串,那么一定要在条件中将数据使用引号引起来,否则不使用索引。5、  如果mysql估计使用全表扫描要比使用索引快,则不使用索引。  查看索引的使用情况     Show status  like   ‘handler_read%’;
mysql数据库优化语句_MySQL
 只有handler_read_key  越大越好     Handler_read_rnd_next  越小越好  数据库类型:             MyISAM  不支持事务和外键,一张表由三个文件组成,.frm  .myi  .myd             innoDB    支持事务和外键                            对于MyISAM来说查询快,不过删除字段时空间是不会释放的,必须使用手动释放        optimize   table  table_name     数据库分表:1、  水平分表
mysql数据库优化语句_MySQL 2、  垂直分表:  Stu表:     id     Name     Pass     PhotoMark表     Id     Sid     Question     answer垂直分表针对于关联类型的表,比如说,有一个学生的个人信息(有头像)表,一个考试信息(考试题和答案)表,这时我想查一个学生的考试分数和个人信息,那么mysql会将学生的个人信息和考试信息表关联,速度回降低很多,所以要将考试信息中的答案和题目分开在创建一个表,如果在提高还可以将头像分开为一个单独的表(如百度单独的图片服务器) 读写分离:
mysql数据库优化语句_MySQL
   作者 web8 bitsCN.com

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 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. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
2 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
2 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
2 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

PHP에서 MySQL 백업 및 복원을 사용하는 방법은 무엇입니까? PHP에서 MySQL 백업 및 복원을 사용하는 방법은 무엇입니까? Jun 03, 2024 pm 12:19 PM

PHP에서 MySQL 데이터베이스를 백업하고 복원하는 작업은 다음 단계에 따라 수행할 수 있습니다. 데이터베이스 백업: mysqldump 명령을 사용하여 데이터베이스를 SQL 파일로 덤프합니다. 데이터베이스 복원: mysql 명령을 사용하여 SQL 파일에서 데이터베이스를 복원합니다.

PHP에서 MySQL 쿼리 성능을 최적화하는 방법은 무엇입니까? PHP에서 MySQL 쿼리 성능을 최적화하는 방법은 무엇입니까? Jun 03, 2024 pm 08:11 PM

선형 복잡성에서 로그 복잡성까지 조회 시간을 줄이는 인덱스를 구축하여 MySQL 쿼리 성능을 최적화할 수 있습니다. SQL 삽입을 방지하고 쿼리 성능을 향상하려면 PREPAREDStatements를 사용하세요. 쿼리 결과를 제한하고 서버에서 처리되는 데이터의 양을 줄입니다. 적절한 조인 유형 사용, 인덱스 생성, 하위 쿼리 사용 고려 등 조인 쿼리를 최적화합니다. 쿼리를 분석하여 병목 현상을 식별하고, 캐싱을 사용하여 데이터베이스 로드를 줄이고, 오버헤드를 최소화합니다.

PHP를 사용하여 MySQL 테이블에 데이터를 삽입하는 방법은 무엇입니까? PHP를 사용하여 MySQL 테이블에 데이터를 삽입하는 방법은 무엇입니까? Jun 02, 2024 pm 02:26 PM

MySQL 테이블에 데이터를 삽입하는 방법은 무엇입니까? 데이터베이스에 연결: mysqli를 사용하여 데이터베이스에 대한 연결을 설정합니다. SQL 쿼리 준비: 삽입할 열과 값을 지정하는 INSERT 문을 작성합니다. 쿼리 실행: query() 메서드를 사용하여 삽입 쿼리를 실행하면 확인 메시지가 출력됩니다.

PHP를 사용하여 MySQL 테이블을 만드는 방법은 무엇입니까? PHP를 사용하여 MySQL 테이블을 만드는 방법은 무엇입니까? Jun 04, 2024 pm 01:57 PM

PHP를 사용하여 MySQL 테이블을 생성하려면 다음 단계가 필요합니다. 데이터베이스에 연결합니다. 데이터베이스가 없으면 작성하십시오. 데이터베이스를 선택합니다. 테이블을 생성합니다. 쿼리를 실행합니다. 연결을 닫습니다.

PHP에서 MySQL 저장 프로시저를 사용하는 방법은 무엇입니까? PHP에서 MySQL 저장 프로시저를 사용하는 방법은 무엇입니까? Jun 02, 2024 pm 02:13 PM

PHP에서 MySQL 저장 프로시저를 사용하려면: PDO 또는 MySQLi 확장을 사용하여 MySQL 데이터베이스에 연결합니다. 저장 프로시저를 호출하는 문을 준비합니다. 저장 프로시저를 실행합니다. 결과 집합을 처리합니다(저장 프로시저가 결과를 반환하는 경우). 데이터베이스 연결을 닫습니다.

MySQL 8.4에서 mysql_native_password가 로드되지 않음 오류를 수정하는 방법 MySQL 8.4에서 mysql_native_password가 로드되지 않음 오류를 수정하는 방법 Dec 09, 2024 am 11:42 AM

MySQL 8.4(2024년 최신 LTS 릴리스)에 도입된 주요 변경 사항 중 하나는 "MySQL 기본 비밀번호" 플러그인이 더 이상 기본적으로 활성화되지 않는다는 것입니다. 또한 MySQL 9.0에서는 이 플러그인을 완전히 제거합니다. 이 변경 사항은 PHP 및 기타 앱에 영향을 미칩니다.

오라클 데이터베이스와 mysql의 차이점 오라클 데이터베이스와 mysql의 차이점 May 10, 2024 am 01:54 AM

Oracle 데이터베이스와 MySQL은 모두 관계형 모델을 기반으로 하는 데이터베이스이지만 호환성, 확장성, 데이터 유형 및 보안 측면에서 Oracle이 우수하고, MySQL은 속도와 유연성에 중점을 두고 중소 규모 데이터 세트에 더 적합합니다. ① Oracle은 광범위한 데이터 유형을 제공하고, ② 고급 보안 기능을 제공하고, ③ 엔터프라이즈급 애플리케이션에 적합하고, ① MySQL은 NoSQL 데이터 유형을 지원하고, ② 보안 조치가 적고, ③ 중소 규모 애플리케이션에 적합합니다.

Mistral 오픈 소스 코드 모델이 왕좌를 차지했습니다! Codestral은 80개 이상의 언어로 교육하는 데 열중하고 있으며 국내 Tongyi 개발자들이 참여를 요청하고 있습니다! Mistral 오픈 소스 코드 모델이 왕좌를 차지했습니다! Codestral은 80개 이상의 언어로 교육하는 데 열중하고 있으며 국내 Tongyi 개발자들이 참여를 요청하고 있습니다! Jun 08, 2024 pm 09:55 PM

51CTO Technology Stack(WeChat ID: blog51cto)에서 제작 Mistral이 첫 번째 코드 모델 Codestral-22B를 출시했습니다! 이 모델의 놀라운 점은 많은 코드 모델이 무시하는 Swift 등을 포함하여 80개 이상의 프로그래밍 언어로 훈련되었다는 것 뿐만이 아닙니다. 그들의 속도는 정확히 동일하지 않습니다. Go 언어를 사용하여 "게시/구독" 시스템을 작성해야 합니다. 여기 GPT-4o가 출력되고 있는데 Codestral이 종이를 너무 빨리 넘겨서 보기 힘들 정도예요! 해당 모델은 출시된 지 얼마 되지 않아 아직 공개 테스트를 거치지 않았습니다. 하지만 Mistral 담당자에 따르면 Codestral은 현재 가장 성능이 좋은 오픈 소스 코드 모델입니다. 사진에 관심 있는 친구들은 다음으로 이동할 수 있습니다. - 얼굴을 안아주세요: https

See all articles