4

我的调试模型中有 1 个函数,我想使用它来向我的应用程序添加虚拟数据以测试它的速度等......

问题是它需要将记录添加到 2 个不同的表中,并在将每条记录添加到数据库之前检查重复的用户名等,因此需要一些时间......

这个过程也重复了关于 $total 不同的虚拟记录,我想在 for 循环中一次添加......

例如,对于 100 个新用户,我想添加它大约需要 5 秒才能继续。

这次很好还是我需要优化它?

如果我想一次添加 1000,10000 个用户怎么办?是否可以?

编辑: 调用插入数据的函数:

public function registerRandomUsers($total = 1){
    $this->load->model("misc_model");
    $this->load->model("encryption_model");
    $this->load->model("signup_model");

    for ($i=1;$i<=$total;$i++){
        $username = $this->misc_model->generateRandomString(15);
        $flag = false;
        while ($flag == false){
            if ($this->user_model->usernameExist($username)){
                $username = $this->misc_model->generateRandomString(15);
            }else{
                $flag = true;

                $password = 'Test123';
                $email = $username.'@email.com';
                $data = array(
                    'username' => $username,
                    'password' => $password,
                    'email' => $email
                );
                $this->signup_model->submitRegistration($data);
                $userdata = $this->user_model->getUserData($username, "username");
            }
        }
    }
}
4

3 回答 3

2

如果您不担心将随机字符串作为用户名,只需设置$email = 'user'.$i.'@email.com'; (这样您就不必担心冲突)。这将运行缓慢的主要原因是因为您在循环的每次迭代中都向数据库发送新查询 - 生成批量插入字符串会快得多,例如:

INSERT INTO user (email,pass)
VALUES ('user1@email.com','Test123')
,      ('user2@email.com','Test123')
,      ('user3@email.com','Test123')
,      ('user4@email.com','Test123')
,      ('user5@email.com','Test123');

这样,您可以避免向数据库发送 10000 个查询的 tcp 流量开销,并一次性完成所有操作。

于 2012-04-17T11:58:57.100 回答
2

我认为如果你真的在寻找一些真实的样本/测试数据,你应该使用generateata.com

http://www.generateddata.com/

这是迄今为止我见过的最好的之一。

于 2012-04-17T12:01:08.423 回答
1

像这样构建您的查询

$conjuctions = str_repeat("('dummy@email.com','test pass'),", 20); // 20 dummy datas
$query = "INSERT INTO user (email,pass) VALUES ".substr($conjunctions,0,str_len($conjuctions).";"
                                               // ^ This is to remove the last comma
于 2012-04-17T12:09:20.887 回答