【发布时间】:2019-03-18 13:34:21
【问题描述】:
我一直在对各种语言的 MySQL 执行性能进行一些测试,以衡量它们的整体执行时间,而结果对我来说似乎完全不正确。
测试的主要目标是查看从数据库表中提取数据列表、将该数据转储到对象数组中、然后将该数据输出到屏幕上需要多少秒。根据我得到的数字,我唯一的假设是我必须在 Java 和 Kotlin 中做一些完全错误的事情,否则根据结果,它们的执行速度要慢得多。虽然这没有任何意义,因为它们都是编译语言,所以它们的性能应该很容易比较,如果不超过 PHP 的性能的话。
现在我假设我的代码下面有一些东西导致执行时间比 PHP 慢得多,并且很好奇是否有人对可能发生的事情有任何输入,或者 Java mysql 连接器只是一个比 PHP 中的 PDO 连接器慢很多?
PHP:0.21993803977966
科特林:0.783954305
Java: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 );
【问题讨论】:
-
发布 PHP 等效代码,以便我们可以看到您正在将苹果与苹果进行比较。我的猜测是 PHP 代码不包括设置与数据库的连接的时间。
-
另请注意,Java 使用即时编译,这可能不会在这里发挥作用。要进行更可靠的基准测试,您应该使用JMH
-
@NotaJD 谢谢,刚刚添加了 PHP 代码示例...
-
@Kabe 值得注意的是,您的计算不正确:您使用
elapsedTime / 1_000_000_000.0,elapsedTime以纳秒为单位进行测量,但使用微秒时您使用( ( $endtime - $starttime ) / 1000)。应该是( ( $endtime - $starttime ) / 1000000)。1 ns = 1e-9 s,1 μs = 1e-6 s. -
也尝试在之后建立连接。这通常是一次性(或几次)问题,因为建立数据库连接并不便宜。