mysql数据库3600万测试数据生成方法及优化测试

为公司项目优化调整,需要大容量数据表做测试,测试过程发现了很多有趣的东西,这里一并发出来。

本次测试为myISAM表的大容量数据查询优化所做的测试数据,在测试过程中使用了merge分表,每张表1800万数据,对程序来说,分表操作被包装起来,程序操作如同是同一张表,测试结果较为满意,各位看官可以使用本方法的命令行运行来生成测试数据,也可以借鉴merge分表来拆分大容量数据。

测试数据表准备

CREATE TABLE `time_1` (
`id` bigint(20) NOT NULL AUTO_INCREMENT,
`confid` int(11) NOT NULL,
`timeid` int(11) NOT NULL,
PRIMARY KEY (`id`),
KEY `confid` (`confid`),
KEY `timeid` (`timeid`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8

CREATE TABLE `testtime` (
`id` bigint(20) NOT NULL AUTO_INCREMENT ,
`confid` int(11) NOT NULL,
`timeid` int(11) NOT NULL,
PRIMARY KEY (`id`),
KEY `confid` (`confid`),
KEY `timeid` (`timeid`)
) ENGINE=MRG_MyISAM DEFAULT CHARSET=utf8 INSERT_METHOD = last UNION = ( `time_1` )

这里准备了两张表,testtime为主表,time_1为第一张分表,现在开始插入数据,在命令行下运行下列代码

<?php
/*3600万测试数据生成方法,每张表1800万数据,在命令行模式下运行*/

$con[email protected]mysql_connect(‘localhost‘,‘root‘,‘root‘);
if(!$con){
     die("no".mysql_error());
}else{
     echo "yes!";
}
mysql_select_db("test", $con);
mysql_query("SET NAMES utf8");

$contime_start=20150101;
$confid=mt_rand(100000,999999);
$i=$v=0;
while($v<1800){
     $confid=mt_rand(100000,999999);
     while($i<100){
          $sql="insert into testtime values(‘‘,{$confid},{$contime_start})";
          for($t=0;$t<100;$t++){
               $contime_start++;
               $sql.=",(‘‘,{$confid},{$contime_start})";
          }
          if (mysql_query($sql,$con)){
               echo "insert ok ".$v.‘----‘.$i."\r\n";
          }else{
               echo "Error creating database: " . mysql_error();
               exit();
          }
          $i++;
     }

     $i=0;
     $v++;
     echo $v."\r\n";
}

插入完成,现在生成第二张分表

CREATE TABLE `time_2` (
`id` bigint(20) NOT NULL AUTO_INCREMENT,
`confid` int(11) NOT NULL,
`timeid` int(11) NOT NULL,
PRIMARY KEY (`id`),
KEY `confid` (`confid`),
KEY `timeid` (`timeid`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8

alter table testtime engine=mrg_myisam union=(`time_1`,`time_2` ) insert_method=last;

现在再次运行上列的php数据生成文件,将会发先随后的1800数据插入了第二张表time_2.

所以,这种方法可以随时merge新表进testtime表中,而程序操作数据库,只需要面对testtime即可,非常方便,查询结果以id或者confid查询timeid,简单优化部分mysql参数后,查询速度不超过0.4秒,面对3600万数据这个结果已经相当满意了,实际应用中,我们的表超过200万数据可能就需要分表了。

这里大家可以看到merge分表的方便和强大,但是大家有没有注意到每张分表里的索引和数据字段。

简单的说一下结论,如果不是int字段索引,如果查询不以已索引字段为where第一条件,如果被查询字段中有大量的未索引字段,那么速度会很受影响,这点务必注意。大家在测试中也可以体会下。

时间: 2024-08-09 02:20:56

mysql数据库3600万测试数据生成方法及优化测试的相关文章

Java连接MySQL数据库增删改查通用方法

Java连接MySQL数据库增删改查通用方法 运行环境:eclipse+MySQL 以前我们Java连接MySQL数据库都是一个数据库写一个类,类下面写好多方法,要是多个数据库,就要写多个类多个方法,导致代码编写太过于繁琐,所以为了改变这样的繁琐,我将连接数据库的方法进行了一系列的封装,使用户传入一个对象值Object就可以得到想要的. 我在之前写过一篇普通的Java连接MySQL数据库,大家可以看看,以便对比参考之后就知道差距了  数据库--MySQL-->Java篇 接下来我给大家讲讲如何将

一:MySQL数据库的性能的影响分析及其优化

MySQL数据库的性能的影响分析及其优化 MySQL数据库的性能的影响 一. 服务器的硬件的限制 二. 服务器所使用的操作系统 三. 服务器的所配置的参数设置不同 四. 数据库存储引擎的选择 五. 数据库的参数配置的不同 六. (重点)数据库的结构的设计和SQL语句 1). 服务器的配置和设置(cpu和可用的内存的大小) 1.网络和I/O资源 2.cpu的主频和核心的数量的选择 (对于密集型的应用应该优先考虑主频高的cpu) (对于并发量大的应用优先考虑的多核的cpu) 3.磁盘的配置和选择 (

浅谈MySQL数据库备份的几种方法

mysql常见的备份方式有:mysqldump.mysqlhotcopy.BACKUP TABLE .SELECT INTO OUTFILE,又或者备份二进制日志(binlog),还可以是直接拷贝数据文件和相关的配置文件.MyISAM 表是保存成文件的形式,因此相对比较容易备份,上面提到的几种方法都可以使用.Innodb 所有的表都保存在同一个数据文件 ibdata1 中(也可能是多个文件,或者是独立的表空间文件),相对来说比较不好备份,免费的方案可以是拷贝数据文件.备份 binlog,或者用 

Hinernate进行mysql数据库的逆向工程无法生成主外键关系

(1)我们在进行SSH开发大※的项目的时候,使用myeclipse自带的hibernate的逆向工程工具时,发现竟然无法生成one-to-one  one-to-many等的主外键关系,明明的数据库建时已经有主外键关系了.为啥逆向生成时就不行了呢? (2)首先说一下,我使用的是PHP开发环境Appserv自带的MySQL数据库,不是单独安装的: (3)这是因为数据库引擎的问题, 我们可以在sql命令行中输入命令:show engines; 可以看到default默认的是MyISAM: (3)"M

mysql数据库改名的三种方法

前不久去面试,被问到Innodb引擎的表如何改数据库名,当时我也只回答了MyISAM改如何操作,被一些细节问题打败,真是操蛋. 如果表示MyISAM那么可以直接去到数据库目录mv就可以. Innodb完全不行,自己测试过,会提示相关表不存在. 第一种方法: RENAME database olddbname TO newdbname 这个是5.1.7到5.1.23版本可以用的,但是官方不推荐,会有丢失数据的危险 第二种方法: 1.创建需要改成新名的数据库.2.mysqldum 导出要改名的数据库

Ubuntu server 安装的mysql数据库忘记密码的解决方法

客户端连接时报错MySQL数据库出现:Error 1045错误时,就表明输入的用户名或密码错误被拒绝访问了. 解决办法可以分为以下几步: 1.修改mysql配置文件,使得可以无密码登录mysql sudo vim /etc/mysql/my.cnf 在[mysqld]项下添加 skip-grant-tables 2.重启mysql服务 sudo service mysql restart 3.无密码登录mysql mysql -uroot -p 4.修改管理员密码 use mysql; upda

MySQL数据库root密码丢失破解方法

MySQL密码丢失破解方法 第1章 单实例破解方法 1.1 停止mysql服务 [[email protected] ~]# /etc/init.d/mysqld stop Shutting down MySQL. SUCCESS! 1.2 重新启动mysql启动 直接使用mysqld_safe命令启动,并添加参数--skip-grant-tables,跳过权限认证表 [[email protected] ~]# mysqld_safe --skip-grant-tables & [1] 598

mysql数据库.sql备份文件的恢复方法

这里介绍两种方法: 1. mysqldump mysqldump不需要登录到数据库中就可以备份和恢复库和表: (1)备份 mysqldump -uroot -p‘123123’ mytest > /mnt/mytest_bak_$(date +%F).sql #注意这里是在命令行操作的,不是在mysql数据中,所以也不会有冒号 (2)恢复 mysql -uroot -p'123456' mytest < /mnt/mytest_bak_2019-10-10.sql 2. source (1)如

自动备份mysql数据库并发送到Email方法

一个博客,一个网站最重要的就是数据库,所以经常备份数据是必须的.尽管 WordPress 有定时备份数据的插件,但只能备份当前的博客,不够灵活.适合个人小小博客,对于一些网站来说,就不适合了.现在很多人都拥有多个网站,showfom 同学就有几个网站.每个网站都装个插件就比较麻烦了.况且不是每个网站都是 WordPress 的 . 所以写了个自动备份mysql数据库的脚本,再加上gmail这个G级邮箱,备份多少数据都可以了...下面是代码: mysqldump -uuser -ppassword