mysql数据库优化语句
1、 数据库表 要设计合理(符合3NF,有时候也需要适当的逆范式)
2、 Sql语句的优化(索引,常用小技巧)
4、 适当的硬件配置和操作系统
问:什么是数据库3范式?
1NF: 就是具有原子性,不可分割(只要使用的是关系型数据库,就会自动符合)
2NF: 在满足1NF的基础上,我们考虑是否满足2NF,只要表的记录满足唯一性,也就是说,你的同一张表中不可能出现完全相同的记录,一般说我们在表中设计一个主键即可。
3NF: 在满足2NF: 的基础上,我们考虑是否满足3NF,既我们的字段信息可以通过关联的关系,派生即可(通常我们通过外键来处理)使用外键数据库的存储引擎必须是innoDB
对于innodb存储引擎最重要的就是内存,所以下面的两个参数调的很大
二、显示试图连接Mysql服务器的次数
四、如何在一个项目中,找到慢查询的select,mysql数据库支持把慢查询的语句记录到日志中,供程序员来分析
1、 启动mysql(特殊的启动方式)
在那些列上添加索引比较合适:
1、比较频繁的作为查询条件的字段应该加上索引
2、 唯一性比较差的字段不适合单独创建索引,及时频繁作为查询条件
3、 更新非常频繁的字段不适合创建索引
4、 不会出现在where子句中的字段不该创建索引
1、 对于创建的多列索引,只要查询条件使用了最左边的列,索引一般就会被使用
2、 对于使用like的查询,查询如果是‘%aaa’不会使用到索引‘aaa%’会使用到索引
1、 如果条件中有or,即使其中有条件带索引也不会使用
2、 对于多列索引,不是使用的第一部分,则不会使用索引
4、 如果列类型是字符串,那么一定要在条件中将数据使用引号引起来,否则不使用索引。
5、 如果mysql估计使用全表扫描要比使用索引快,则不使用索引。
垂直分表针对于关联类型的表,比如说,有一个学生的个人信息(有头像)表,一个考试信息(考试题和答案)表,这时我想查一个学生的考试分数和个人信息,那么mysql会将学生的个人信息和考试信息表关联,速度回降低很多,所以要将考试信息中的答案和题目分开在创建一个表,如果在提高还可以将头像分开为一个单独的表(如百度单独的图片服务器)
1、用dump命令备份数据库。
2、用rsync从新服务器获得备份的文件(SCP或WGET也可以)。
3、登陆新服务器的mysql客户端。
在Mysql程序中有我自己的一个数据库共5张表,里边数据不算太多。我现在想把他们全部弄到另一台电脑中去,该怎么弄,如果不用其它的软件工具,只用Mysql自已的程序不知可否?
注:不用考虑操作系统。
在dos命令提示符下使用mysqldump命令进行备份.
-u,-p参数后面跟的分别是用户名和密码.
将你备份出来的文件我这里是backup.txt拷贝到另一台机上,再在dos命令提示符下用mysql命令,进行恢复,如下:
如果另一台机器上也安装了mysql,可以直接导入
将A机器上的mysql/data下的你的数据库目录整个拷贝下来。
将B机器上的mysql服务停止。
找到B机器上的mysql/data目录,将你拷贝的目录粘贴进去,然后启动mysql服务就可以了。
2、使用SQL语句备份和恢复
你可以使用SELECT INTO OUTFILE语句备份数据,并用LOAD DATA INFILE语句恢复数据。这种方法只能导出数据的内容,不包括表的结构,如果表的结构文件损坏,你必须要先恢复原来的表的结构。