2015-06-16 15:04:20 +12:00
|
|
|
<?php
|
2016-06-15 16:03:16 +12:00
|
|
|
|
2016-10-14 14:30:05 +13:00
|
|
|
namespace SilverStripe\ORM\Tests;
|
|
|
|
|
2016-11-13 20:35:43 +13:00
|
|
|
use SilverStripe\ORM\Connect\PDOQuery;
|
2016-06-15 16:03:16 +12:00
|
|
|
use SilverStripe\ORM\DB;
|
|
|
|
use SilverStripe\ORM\Connect\PDOConnector;
|
|
|
|
use SilverStripe\ORM\Queries\SQLUpdate;
|
2016-08-19 10:51:35 +12:00
|
|
|
use SilverStripe\Dev\SapphireTest;
|
|
|
|
|
2017-07-03 12:21:27 +12:00
|
|
|
/**
|
|
|
|
* @skipUpgrade
|
|
|
|
*/
|
2016-12-16 17:34:21 +13:00
|
|
|
class PDODatabaseTest extends SapphireTest
|
|
|
|
{
|
|
|
|
protected static $fixture_file = 'MySQLDatabaseTest.yml';
|
|
|
|
|
2020-04-20 18:58:09 +01:00
|
|
|
protected static $extra_dataobjects = [
|
2016-12-16 17:34:21 +13:00
|
|
|
MySQLDatabaseTest\Data::class
|
2020-04-20 18:58:09 +01:00
|
|
|
];
|
2016-12-16 17:34:21 +13:00
|
|
|
|
|
|
|
public function testPreparedStatements()
|
|
|
|
{
|
|
|
|
if (!(DB::get_connector() instanceof PDOConnector)) {
|
|
|
|
$this->markTestSkipped('This test requires the current DB connector is PDO');
|
|
|
|
}
|
|
|
|
|
|
|
|
// Test preparation of equivalent statemetns
|
|
|
|
$result1 = DB::get_connector()->preparedQuery(
|
|
|
|
'SELECT "Sort", "Title" FROM "MySQLDatabaseTest_Data" WHERE "Sort" > ? ORDER BY "Sort"',
|
2020-04-20 18:58:09 +01:00
|
|
|
[0]
|
2016-12-16 17:34:21 +13:00
|
|
|
);
|
|
|
|
|
|
|
|
$result2 = DB::get_connector()->preparedQuery(
|
|
|
|
'SELECT "Sort", "Title" FROM "MySQLDatabaseTest_Data" WHERE "Sort" > ? ORDER BY "Sort"',
|
2020-04-20 18:58:09 +01:00
|
|
|
[2]
|
2016-12-16 17:34:21 +13:00
|
|
|
);
|
|
|
|
$this->assertInstanceOf(PDOQuery::class, $result1);
|
|
|
|
$this->assertInstanceOf(PDOQuery::class, $result2);
|
|
|
|
|
|
|
|
// Also select non-prepared statement
|
|
|
|
$result3 = DB::get_connector()->query('SELECT "Sort", "Title" FROM "MySQLDatabaseTest_Data" ORDER BY "Sort"');
|
|
|
|
$this->assertInstanceOf(PDOQuery::class, $result3);
|
|
|
|
|
|
|
|
// Iterating one level should not buffer, but return the right result
|
|
|
|
$this->assertEquals(
|
2020-04-20 18:58:09 +01:00
|
|
|
[
|
2016-12-16 17:34:21 +13:00
|
|
|
'Sort' => 1,
|
|
|
|
'Title' => 'First Item'
|
2020-04-20 18:58:09 +01:00
|
|
|
],
|
2016-12-16 17:34:21 +13:00
|
|
|
$result1->next()
|
|
|
|
);
|
|
|
|
$this->assertEquals(
|
2020-04-20 18:58:09 +01:00
|
|
|
[
|
2016-12-16 17:34:21 +13:00
|
|
|
'Sort' => 2,
|
|
|
|
'Title' => 'Second Item'
|
2020-04-20 18:58:09 +01:00
|
|
|
],
|
2016-12-16 17:34:21 +13:00
|
|
|
$result1->next()
|
|
|
|
);
|
|
|
|
|
|
|
|
// Test first
|
|
|
|
$this->assertEquals(
|
2020-04-20 18:58:09 +01:00
|
|
|
[
|
2016-12-16 17:34:21 +13:00
|
|
|
'Sort' => 1,
|
|
|
|
'Title' => 'First Item'
|
2020-04-20 18:58:09 +01:00
|
|
|
],
|
2016-12-16 17:34:21 +13:00
|
|
|
$result1->first()
|
|
|
|
);
|
|
|
|
|
|
|
|
// Test seek
|
|
|
|
$this->assertEquals(
|
2020-04-20 18:58:09 +01:00
|
|
|
[
|
2016-12-16 17:34:21 +13:00
|
|
|
'Sort' => 2,
|
|
|
|
'Title' => 'Second Item'
|
2020-04-20 18:58:09 +01:00
|
|
|
],
|
2016-12-16 17:34:21 +13:00
|
|
|
$result1->seek(1)
|
|
|
|
);
|
|
|
|
|
|
|
|
// Test count
|
|
|
|
$this->assertEquals(4, $result1->numRecords());
|
|
|
|
|
|
|
|
// Test second statement
|
|
|
|
$this->assertEquals(
|
2020-04-20 18:58:09 +01:00
|
|
|
[
|
2016-12-16 17:34:21 +13:00
|
|
|
'Sort' => 3,
|
|
|
|
'Title' => 'Third Item'
|
2020-04-20 18:58:09 +01:00
|
|
|
],
|
2016-12-16 17:34:21 +13:00
|
|
|
$result2->next()
|
|
|
|
);
|
|
|
|
|
|
|
|
// Test non-prepared query
|
|
|
|
$this->assertEquals(
|
2020-04-20 18:58:09 +01:00
|
|
|
[
|
2016-12-16 17:34:21 +13:00
|
|
|
'Sort' => 1,
|
|
|
|
'Title' => 'First Item'
|
2020-04-20 18:58:09 +01:00
|
|
|
],
|
2016-12-16 17:34:21 +13:00
|
|
|
$result3->next()
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testAffectedRows()
|
|
|
|
{
|
|
|
|
if (!(DB::get_connector() instanceof PDOConnector)) {
|
|
|
|
$this->markTestSkipped('This test requires the current DB connector is PDO');
|
|
|
|
}
|
|
|
|
|
2017-11-17 12:35:55 +13:00
|
|
|
$query = new SQLUpdate('"MySQLDatabaseTest_Data"');
|
2020-04-20 18:58:09 +01:00
|
|
|
$query->setAssignments(['"Title"' => 'New Title']);
|
2016-12-16 17:34:21 +13:00
|
|
|
|
|
|
|
// Test update which affects no rows
|
2020-04-20 18:58:09 +01:00
|
|
|
$query->setWhere(['"Title"' => 'Bob']);
|
2016-12-16 17:34:21 +13:00
|
|
|
$result = $query->execute();
|
|
|
|
$this->assertInstanceOf(PDOQuery::class, $result);
|
|
|
|
$this->assertEquals(0, DB::affected_rows());
|
|
|
|
|
|
|
|
// Test update which affects some rows
|
2020-04-20 18:58:09 +01:00
|
|
|
$query->setWhere(['"Title"' => 'First Item']);
|
2016-12-16 17:34:21 +13:00
|
|
|
$result = $query->execute();
|
|
|
|
$this->assertInstanceOf(PDOQuery::class, $result);
|
|
|
|
$this->assertEquals(1, DB::affected_rows());
|
|
|
|
}
|
2016-01-06 12:34:58 +13:00
|
|
|
}
|