Merge pull request #7323 from owncloud/Jonny007-MKD-master
Update adapter.php
This commit is contained in:
commit
353155b516
3 changed files with 41 additions and 6 deletions
|
@ -51,13 +51,18 @@ class Adapter {
|
||||||
. str_repeat('?,', count($input)-1).'? ' // Is there a prettier alternative?
|
. str_repeat('?,', count($input)-1).'? ' // Is there a prettier alternative?
|
||||||
. 'FROM `' . $table . '` WHERE ';
|
. 'FROM `' . $table . '` WHERE ';
|
||||||
|
|
||||||
|
$inserts = array_values($input);
|
||||||
foreach($input as $key => $value) {
|
foreach($input as $key => $value) {
|
||||||
$query .= '`' . $key . '` = ? AND ';
|
$query .= '`' . $key . '`';
|
||||||
|
if (is_null($value)) {
|
||||||
|
$query .= ' IS NULL AND ';
|
||||||
|
} else {
|
||||||
|
$inserts[] = $value;
|
||||||
|
$query .= ' = ? AND ';
|
||||||
|
}
|
||||||
}
|
}
|
||||||
$query = substr($query, 0, strlen($query) - 5);
|
$query = substr($query, 0, strlen($query) - 5);
|
||||||
$query .= ' HAVING COUNT(*) = 0';
|
$query .= ' HAVING COUNT(*) = 0';
|
||||||
$inserts = array_values($input);
|
|
||||||
$inserts = array_merge($inserts, $inserts);
|
|
||||||
|
|
||||||
try {
|
try {
|
||||||
return $this->conn->executeUpdate($query, $inserts);
|
return $this->conn->executeUpdate($query, $inserts);
|
||||||
|
|
|
@ -21,13 +21,21 @@ class AdapterSqlite extends Adapter {
|
||||||
// NOTE: For SQLite we have to use this clumsy approach
|
// NOTE: For SQLite we have to use this clumsy approach
|
||||||
// otherwise all fieldnames used must have a unique key.
|
// otherwise all fieldnames used must have a unique key.
|
||||||
$query = 'SELECT COUNT(*) FROM `' . $table . '` WHERE ';
|
$query = 'SELECT COUNT(*) FROM `' . $table . '` WHERE ';
|
||||||
foreach($input as $key => $value) {
|
$inserts = array();
|
||||||
$query .= '`' . $key . '` = ? AND ';
|
foreach ($input as $key => $value) {
|
||||||
|
$query .= '`' . $key . '`';
|
||||||
|
if (is_null($value)) {
|
||||||
|
$query .= ' IS NULL AND ';
|
||||||
|
} else {
|
||||||
|
$inserts[] = $value;
|
||||||
|
$query .= ' = ? AND ';
|
||||||
|
}
|
||||||
}
|
}
|
||||||
$query = substr($query, 0, strlen($query) - 5);
|
$query = substr($query, 0, strlen($query) - 5);
|
||||||
|
|
||||||
try {
|
try {
|
||||||
$stmt = $this->conn->prepare($query);
|
$stmt = $this->conn->prepare($query);
|
||||||
$result = $stmt->execute(array_values($input));
|
$result = $stmt->execute($inserts);
|
||||||
} catch(\Doctrine\DBAL\DBALException $e) {
|
} catch(\Doctrine\DBAL\DBALException $e) {
|
||||||
$entry = 'DB Error: "'.$e->getMessage() . '"<br />';
|
$entry = 'DB Error: "'.$e->getMessage() . '"<br />';
|
||||||
$entry .= 'Offending command was: ' . $query . '<br />';
|
$entry .= 'Offending command was: ' . $query . '<br />';
|
||||||
|
|
|
@ -125,6 +125,28 @@ class Test_DB extends PHPUnit_Framework_TestCase {
|
||||||
$this->assertEquals(4, count($result->fetchAll()));
|
$this->assertEquals(4, count($result->fetchAll()));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function testInsertIfNotExistNull() {
|
||||||
|
$categoryentries = array(
|
||||||
|
array('addressbookid' => 123, 'fullname' => null, 'expectedResult' => 1),
|
||||||
|
array('addressbookid' => 123, 'fullname' => null, 'expectedResult' => 0),
|
||||||
|
array('addressbookid' => 123, 'fullname' => 'test', 'expectedResult' => 1),
|
||||||
|
);
|
||||||
|
|
||||||
|
foreach($categoryentries as $entry) {
|
||||||
|
$result = OC_DB::insertIfNotExist('*PREFIX*'.$this->table2,
|
||||||
|
array(
|
||||||
|
'addressbookid' => $entry['addressbookid'],
|
||||||
|
'fullname' => $entry['fullname'],
|
||||||
|
));
|
||||||
|
$this->assertEquals($entry['expectedResult'], $result);
|
||||||
|
}
|
||||||
|
|
||||||
|
$query = OC_DB::prepare('SELECT * FROM `*PREFIX*'.$this->table2.'`');
|
||||||
|
$result = $query->execute();
|
||||||
|
$this->assertTrue((bool)$result);
|
||||||
|
$this->assertEquals(2, count($result->fetchAll()));
|
||||||
|
}
|
||||||
|
|
||||||
public function testinsertIfNotExistDontOverwrite() {
|
public function testinsertIfNotExistDontOverwrite() {
|
||||||
$fullname = 'fullname test';
|
$fullname = 'fullname test';
|
||||||
$uri = 'uri_1';
|
$uri = 'uri_1';
|
||||||
|
|
Loading…
Reference in a new issue