Merge pull request #10958 from owncloud/db-ilike
Introduce cross-db ILIKE
This commit is contained in:
commit
33f7af9207
|
@ -0,0 +1,17 @@
|
|||
<?php
|
||||
/**
|
||||
* Copyright (c) 2014 Robin Appelman <icewind@owncloud.com>
|
||||
* This file is licensed under the Affero General Public License version 3 or
|
||||
* later.
|
||||
* See the COPYING-README file.
|
||||
*/
|
||||
|
||||
|
||||
namespace OC\DB;
|
||||
|
||||
class AdapterMySQL extends Adapter {
|
||||
public function fixupStatement($statement) {
|
||||
$statement = str_replace(' ILIKE ', ' COLLATE utf8_general_ci LIKE ', $statement);
|
||||
return $statement;
|
||||
}
|
||||
}
|
|
@ -11,18 +11,20 @@ namespace OC\DB;
|
|||
|
||||
class AdapterOCI8 extends Adapter {
|
||||
public function lastInsertId($table) {
|
||||
if($table !== null) {
|
||||
if ($table !== null) {
|
||||
$suffix = '_SEQ';
|
||||
$table = '"'.$table.$suffix.'"';
|
||||
$table = '"' . $table . $suffix . '"';
|
||||
}
|
||||
return $this->conn->realLastInsertId($table);
|
||||
}
|
||||
|
||||
const UNIX_TIMESTAMP_REPLACEMENT = "(cast(sys_extract_utc(systimestamp) as date) - date'1970-01-01') * 86400";
|
||||
|
||||
public function fixupStatement($statement) {
|
||||
$statement = str_replace( '`', '"', $statement );
|
||||
$statement = str_ireplace( 'NOW()', 'CURRENT_TIMESTAMP', $statement );
|
||||
$statement = str_ireplace( 'UNIX_TIMESTAMP()', self::UNIX_TIMESTAMP_REPLACEMENT, $statement );
|
||||
$statement = preg_replace('/`(\w+)` ILIKE \?/', 'REGEXP_LIKE(`$1`, \'^\' || REPLACE(?, \'%\', \'.*\') || \'$\', \'i\')', $statement);
|
||||
$statement = str_replace('`', '"', $statement);
|
||||
$statement = str_ireplace('NOW()', 'CURRENT_TIMESTAMP', $statement);
|
||||
$statement = str_ireplace('UNIX_TIMESTAMP()', self::UNIX_TIMESTAMP_REPLACEMENT, $statement);
|
||||
return $statement;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -11,6 +11,7 @@ namespace OC\DB;
|
|||
|
||||
class AdapterSqlite extends Adapter {
|
||||
public function fixupStatement($statement) {
|
||||
$statement = preg_replace('/`(\w+)` ILIKE \?/', 'LOWER($1) LIKE LOWER(?)', $statement);
|
||||
$statement = str_replace( '`', '"', $statement );
|
||||
$statement = str_ireplace( 'NOW()', 'datetime(\'now\')', $statement );
|
||||
$statement = str_ireplace( 'UNIX_TIMESTAMP()', 'strftime(\'%s\',\'now\')', $statement );
|
||||
|
|
|
@ -11,6 +11,7 @@ namespace OC\DB;
|
|||
|
||||
class AdapterSQLSrv extends Adapter {
|
||||
public function fixupStatement($statement) {
|
||||
$statement = str_replace(' ILIKE ', ' COLLATE Latin1_General_CI_AS LIKE ', $statement);
|
||||
$statement = preg_replace( "/\`(.*?)`/", "[$1]", $statement );
|
||||
$statement = str_ireplace( 'NOW()', 'CURRENT_TIMESTAMP', $statement );
|
||||
$statement = str_replace( 'LENGTH(', 'LEN(', $statement );
|
||||
|
|
|
@ -26,7 +26,7 @@ class ConnectionFactory {
|
|||
'wrapperClass' => 'OC\DB\Connection',
|
||||
),
|
||||
'mysql' => array(
|
||||
'adapter' => '\OC\DB\Adapter',
|
||||
'adapter' => '\OC\DB\AdapterMySQL',
|
||||
'charset' => 'UTF8',
|
||||
'driver' => 'pdo_mysql',
|
||||
'wrapperClass' => 'OC\DB\Connection',
|
||||
|
@ -89,6 +89,9 @@ class ConnectionFactory {
|
|||
case 'oci':
|
||||
$eventManager->addEventSubscriber(new \Doctrine\DBAL\Event\Listeners\OracleSessionInit);
|
||||
break;
|
||||
case 'sqlite3':
|
||||
$eventManager->addEventSubscriber(new SQLiteSessionInit);
|
||||
break;
|
||||
}
|
||||
$connection = \Doctrine\DBAL\DriverManager::getConnection(
|
||||
array_merge($this->getDefaultConnectionParams($type), $additionalConnectionParams),
|
||||
|
|
|
@ -0,0 +1,42 @@
|
|||
<?php
|
||||
/**
|
||||
* Copyright (c) 2014 Robin Appelman <icewind@owncloud.com>
|
||||
* This file is licensed under the Affero General Public License version 3 or
|
||||
* later.
|
||||
* See the COPYING-README file.
|
||||
*/
|
||||
|
||||
namespace OC\DB;
|
||||
|
||||
use Doctrine\DBAL\Event\ConnectionEventArgs;
|
||||
use Doctrine\DBAL\Events;
|
||||
use Doctrine\Common\EventSubscriber;
|
||||
|
||||
class SQLiteSessionInit implements EventSubscriber {
|
||||
/**
|
||||
* @var bool
|
||||
*/
|
||||
private $caseSensitiveLike;
|
||||
|
||||
/**
|
||||
* Configure case sensitive like for each connection
|
||||
*
|
||||
* @param bool $caseSensitiveLike
|
||||
*/
|
||||
public function __construct($caseSensitiveLike = true) {
|
||||
$this->caseSensitiveLike = $caseSensitiveLike;
|
||||
}
|
||||
|
||||
/**
|
||||
* @param ConnectionEventArgs $args
|
||||
* @return void
|
||||
*/
|
||||
public function postConnect(ConnectionEventArgs $args) {
|
||||
$sensitive = ($this->caseSensitiveLike) ? 'true' : 'false';
|
||||
$args->getConnection()->executeUpdate('PRAGMA case_sensitive_like = ' . $sensitive);
|
||||
}
|
||||
|
||||
public function getSubscribedEvents() {
|
||||
return array(Events::postConnect);
|
||||
}
|
||||
}
|
|
@ -464,19 +464,7 @@ class Cache {
|
|||
`mimetype`, `mimepart`, `size`, `mtime`, `encrypted`,
|
||||
`unencrypted_size`, `etag`, `permissions`
|
||||
FROM `*PREFIX*filecache`
|
||||
WHERE `storage` = ? AND ';
|
||||
$dbtype = \OC_Config::getValue( 'dbtype', 'sqlite' );
|
||||
if($dbtype === 'oci') {
|
||||
//remove starting and ending % from the pattern
|
||||
$pattern = '^'.str_replace('%', '.*', $pattern).'$';
|
||||
$sql .= 'REGEXP_LIKE(`name`, ?, \'i\')';
|
||||
} else if($dbtype === 'pgsql') {
|
||||
$sql .= '`name` ILIKE ?';
|
||||
} else if ($dbtype === 'mysql') {
|
||||
$sql .= '`name` COLLATE utf8_general_ci LIKE ?';
|
||||
} else {
|
||||
$sql .= '`name` LIKE ?';
|
||||
}
|
||||
WHERE `storage` = ? AND `name` ILIKE ?';
|
||||
$result = \OC_DB::executeAudited($sql,
|
||||
array($this->getNumericStorageId(), $pattern)
|
||||
);
|
||||
|
|
|
@ -27,6 +27,11 @@ class Test_DB extends PHPUnit_Framework_TestCase {
|
|||
*/
|
||||
private $table3;
|
||||
|
||||
/**
|
||||
* @var string
|
||||
*/
|
||||
private $table4;
|
||||
|
||||
public function setUp() {
|
||||
$dbfile = OC::$SERVERROOT.'/tests/data/db_structure.xml';
|
||||
|
||||
|
@ -263,4 +268,54 @@ class Test_DB extends PHPUnit_Framework_TestCase {
|
|||
$query = OC_DB::prepare("UPDATE `*PREFIX*{$this->table2}` SET `uri` = ? WHERE `fullname` = ?");
|
||||
return $query->execute(array($uri, $fullname));
|
||||
}
|
||||
|
||||
public function testILIKE() {
|
||||
$table = "*PREFIX*{$this->table2}";
|
||||
|
||||
$query = OC_DB::prepare("INSERT INTO `$table` (`fullname`, `uri`, `carddata`) VALUES (?, ?, ?)");
|
||||
$query->execute(array('fooBAR', 'foo', 'bar'));
|
||||
|
||||
$query = OC_DB::prepare("SELECT * FROM `$table` WHERE `fullname` LIKE ?");
|
||||
$result = $query->execute(array('foobar'));
|
||||
$this->assertCount(0, $result->fetchAll());
|
||||
|
||||
$query = OC_DB::prepare("SELECT * FROM `$table` WHERE `fullname` ILIKE ?");
|
||||
$result = $query->execute(array('foobar'));
|
||||
$this->assertCount(1, $result->fetchAll());
|
||||
|
||||
$query = OC_DB::prepare("SELECT * FROM `$table` WHERE `fullname` ILIKE ?");
|
||||
$result = $query->execute(array('foo'));
|
||||
$this->assertCount(0, $result->fetchAll());
|
||||
}
|
||||
|
||||
public function testILIKEWildcard() {
|
||||
$table = "*PREFIX*{$this->table2}";
|
||||
|
||||
$query = OC_DB::prepare("INSERT INTO `$table` (`fullname`, `uri`, `carddata`) VALUES (?, ?, ?)");
|
||||
$query->execute(array('FooBAR', 'foo', 'bar'));
|
||||
|
||||
$query = OC_DB::prepare("SELECT * FROM `$table` WHERE `fullname` LIKE ?");
|
||||
$result = $query->execute(array('%bar'));
|
||||
$this->assertCount(0, $result->fetchAll());
|
||||
|
||||
$query = OC_DB::prepare("SELECT * FROM `$table` WHERE `fullname` LIKE ?");
|
||||
$result = $query->execute(array('foo%'));
|
||||
$this->assertCount(0, $result->fetchAll());
|
||||
|
||||
$query = OC_DB::prepare("SELECT * FROM `$table` WHERE `fullname` LIKE ?");
|
||||
$result = $query->execute(array('%ba%'));
|
||||
$this->assertCount(0, $result->fetchAll());
|
||||
|
||||
$query = OC_DB::prepare("SELECT * FROM `$table` WHERE `fullname` ILIKE ?");
|
||||
$result = $query->execute(array('%bar'));
|
||||
$this->assertCount(1, $result->fetchAll());
|
||||
|
||||
$query = OC_DB::prepare("SELECT * FROM `$table` WHERE `fullname` ILIKE ?");
|
||||
$result = $query->execute(array('foo%'));
|
||||
$this->assertCount(1, $result->fetchAll());
|
||||
|
||||
$query = OC_DB::prepare("SELECT * FROM `$table` WHERE `fullname` ILIKE ?");
|
||||
$result = $query->execute(array('%ba%'));
|
||||
$this->assertCount(1, $result->fetchAll());
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue