169 lines
3.4 KiB
PHP
Raw Normal View History

2013-02-17 21:48:21 -05:00
<?php
namespace PicoDb\Driver;
2013-02-17 21:48:21 -05:00
use PDO;
2015-08-14 21:33:39 -04:00
use PDOException;
2013-02-17 21:48:21 -05:00
2015-08-14 21:33:39 -04:00
/**
* Sqlite Driver
*
* @author Frederic Guillot
*/
class Sqlite extends Base
{
2015-08-14 21:33:39 -04:00
/**
* List of required settings options
*
* @access protected
* @var array
*/
protected $requiredAtttributes = array('filename');
2015-08-14 21:33:39 -04:00
/**
* Create a new PDO connection
*
* @access public
* @param array $settings
*/
public function createConnection(array $settings)
{
$this->pdo = new PDO('sqlite:'.$settings['filename']);
$this->enableForeignKeys();
2013-02-17 21:48:21 -05:00
}
2015-08-14 21:33:39 -04:00
/**
* Enable foreign keys
*
* @access public
*/
public function enableForeignKeys()
2013-02-17 21:48:21 -05:00
{
2015-08-14 21:33:39 -04:00
$this->pdo->exec('PRAGMA foreign_keys = ON');
}
2013-02-17 21:48:21 -05:00
2015-08-14 21:33:39 -04:00
/**
* Disable foreign keys
*
* @access public
*/
public function disableForeignKeys()
{
$this->pdo->exec('PRAGMA foreign_keys = OFF');
}
2013-02-17 21:48:21 -05:00
2015-08-14 21:33:39 -04:00
/**
* Return true if the error code is a duplicate key
*
* @access public
* @param integer $code
* @return boolean
*/
public function isDuplicateKeyError($code)
{
return $code == 23000;
2013-02-17 21:48:21 -05:00
}
2015-08-14 21:33:39 -04:00
/**
* Escape identifier
*
* @access public
* @param string $identifier
* @return string
*/
public function escape($identifier)
2013-02-17 21:48:21 -05:00
{
2015-08-14 21:33:39 -04:00
return '"'.$identifier.'"';
2013-02-17 21:48:21 -05:00
}
2015-08-14 21:33:39 -04:00
/**
* Get non standard operator
*
* @access public
* @param string $operator
* @return string
*/
public function getOperator($operator)
2013-02-17 21:48:21 -05:00
{
2015-08-14 21:33:39 -04:00
if ($operator === 'LIKE' || $operator === 'ILIKE') {
return 'LIKE';
}
return '';
2013-02-17 21:48:21 -05:00
}
2015-08-14 21:33:39 -04:00
/**
* Get last inserted id
*
* @access public
* @return integer
*/
public function getLastId()
2013-02-17 21:48:21 -05:00
{
2015-08-14 21:33:39 -04:00
return $this->pdo->lastInsertId();
2013-02-17 21:48:21 -05:00
}
2015-08-14 21:33:39 -04:00
/**
* Get current schema version
*
* @access public
* @return integer
*/
public function getSchemaVersion()
{
2015-08-14 21:33:39 -04:00
$rq = $this->pdo->prepare('PRAGMA user_version');
$rq->execute();
return (int) $rq->fetchColumn();
}
2015-08-14 21:33:39 -04:00
/**
* Set current schema version
*
* @access public
* @param integer $version
*/
public function setSchemaVersion($version)
{
2015-08-14 21:33:39 -04:00
$this->pdo->exec('PRAGMA user_version='.$version);
}
2015-08-14 21:33:39 -04:00
/**
* Upsert for a key/value variable
*
* @access public
* @param string $table
* @param string $keyColumn
* @param string $valueColumn
* @param array $dictionary
* @return bool False on failure
*/
public function upsert($table, $keyColumn, $valueColumn, array $dictionary)
{
2015-08-14 21:33:39 -04:00
try {
$this->pdo->beginTransaction();
foreach ($dictionary as $key => $value) {
$sql = sprintf(
'INSERT OR REPLACE INTO %s (%s, %s) VALUES (?, ?)',
$this->escape($table),
$this->escape($keyColumn),
$this->escape($valueColumn)
);
$rq = $this->pdo->prepare($sql);
$rq->execute(array($key, $value));
}
$this->pdo->commit();
return true;
}
catch (PDOException $e) {
$this->pdo->rollback();
return false;
}
}
2015-08-14 21:33:39 -04:00
}