1

我一直在对各种语言的 MySQL 执行性能进行一些测试,以衡量它们的整体执行时间,结果对我来说似乎完全不正确。

测试的主要目标是查看从数据库表中提取数据列表、将该数据转储到对象数组中、然后将该数据输出到屏幕上需要多少秒。根据我得到的数字,我唯一的假设是我必须在 Java 和 Kotlin 中做一些完全错误的事情,否则根据结果,它们的执行速度要慢得多。这虽然没有任何意义,因为它们都是编译语言,所以如果不超过 PHP 的性能,它们的性能应该很容易比较。

现在我假设我的代码下面有一些东西导致执行时间比 PHP 慢得多,并且很好奇是否有人对可能发生的事情有任何输入,或者 Java mysql 连接器是否比 PHP 慢很多PHP中的PDO连接器?

PHP: 0.21993803977966

科特林:0.783954305

爪哇:0.716218516

Java 代码

        Long startTime = System.nanoTime();

        Connection conn = DriverManager.getConnection("jdbc:mysql://localhost:3321/database?user=root&password=pass");

        Statement stmt = conn.createStatement();

        StringBuilder stringBuilder = new StringBuilder();

        ArrayList<Entity> contacts = new ArrayList<Entity>();

        ResultSet  rs = stmt.executeQuery( "SELECT * FROM contacts" );

        while( rs.next() ){
            contacts.add( new Entity( rs.getString("firstname"), rs.getString("lastname") ) );
        }

        for( int i = 0; i < 5; i++ ){
            contacts.forEach( contact -> stringBuilder.append("huzzah ").append(contact.getFirstName()).append(" ").append(contact.getLastName()).append("\n\r"));
        }

        Long endTime = System.nanoTime();
        System.out.print( stringBuilder.toString() );

        Long elapsedTime = ( endTime - startTime );

        double seconds = (double) elapsedTime / 1_000_000_000.0;
        System.out.println( "Total Execution Time: " + seconds );

PHP 代码

<?php

$starttime = microtime(true);

include_once "entity.php";

$dbh = new PDO('mysql:host=127.0.0.1;port=3321;dbname=database', "root", "pass");
$query = $dbh->prepare("SELECT * FROM contacts");
$query->execute();

/** @var Entity[] $entities */
$entities = [];

while( $row = $query->fetch(PDO::FETCH_ASSOC)){

    $entities[] = new Entity( $row['firstname'], $row['lastname']);
}

$buffer = "";

for( $i = 0; $i < 5; $i++ ){
    foreach ($entities as $entity) {
        $buffer .= "huzzah {$entity->getFirstName()} {$entity->getLastName()}\n\r";
    }
}

echo $buffer;

$endtime = microtime(true);

echo "Script Time: " . ( $endtime - $starttime );
4

2 回答 2

1

你可以试试:

 ResultSet  rs = stmt.executeQuery( "SELECT * FROM contacts" );
 ArrayList<Entity> contacts = new ArrayList<Entity>(rs.getRow());

    while( rs.next() ){
        contacts.add( new Entity( rs.getString("firstname"), rs.getString("lastname") ) );
    }

这将在一次调用中分配您需要的所有存储空间,而不是为每一行增加存储空间。

永远不要低估 php 的性能和功能。有一半的 WEB 是使用 php 开发的,这是有原因的。

于 2019-03-18T13:52:17.983 回答
1

感谢@Thomas 和@NotaJD 提供答案。用 Java 连接比 PHP 慢得多,所以我指定了数据库连接之后的开始时间。然而,这并不是故事的全部。编译器也没有按照@Thomas 的建议优化代码。我创建了项目的导出 JAR 并进行了一些修改。新时代更加合理,将 Java 的执行时间减少到 0.228579051

        Connection conn = DriverManager.getConnection("jdbc:mysql://localhost:3321/database?user=root&password=password");

        Long startTime = System.nanoTime();

        Statement stmt = conn.createStatement();

        StringBuilder stringBuilder = new StringBuilder();

        ResultSet  rs = stmt.executeQuery( "SELECT * FROM contacts" );

        ArrayList<Entity> contacts = new ArrayList<Entity>(rs.getRow());

        while( rs.next() ){
            contacts.add( new Entity( rs.getString("firstname"), rs.getString("lastname") ) );
        }

        for( int i = 0; i < 5; i++ ){
            contacts.forEach( contact -> stringBuilder.append("huzzah ").append(contact.getFirstName()).append(" ").append(contact.getLastName()).append("\n\r"));
        }

        Long endTime = System.nanoTime();
        System.out.print( stringBuilder.toString() );

        Long elapsedTime = ( endTime - startTime );

        double seconds = (double) elapsedTime / 1_000_000_000.0;
        System.out.println( "Total Execution Time: " + seconds );
于 2019-03-18T14:09:15.003 回答