Commit cec372df authored by zYne's avatar zYne

Doctrine_DataDict_Sqlite driver

parent 70ebe0d9
...@@ -94,10 +94,18 @@ abstract class Doctrine_Connection extends Doctrine_Configurable implements Coun ...@@ -94,10 +94,18 @@ abstract class Doctrine_Connection extends Doctrine_Configurable implements Coun
/** /**
* returns the database handler of which this connection uses * returns the database handler of which this connection uses
* *
* @return object PDO the database handler * @return PDO the database handler
*/ */
public function getDBH() { public function getDBH() {
return $this->dbh; return $this->dbh;
}
/**
* returns a datadict object
*
* @return Doctrine_DataDict
*/
public function getDataDict() {
} }
/** /**
* returns the regular expression operator * returns the regular expression operator
......
...@@ -28,7 +28,7 @@ ...@@ -28,7 +28,7 @@
*/ */
class Doctrine_DataDict { class Doctrine_DataDict {
private $dbh; protected $dbh;
public function __construct(PDO $dbh) { public function __construct(PDO $dbh) {
$file = Doctrine::getPath().DIRECTORY_SEPARATOR."Doctrine".DIRECTORY_SEPARATOR."adodb-hack".DIRECTORY_SEPARATOR."adodb.inc.php"; $file = Doctrine::getPath().DIRECTORY_SEPARATOR."Doctrine".DIRECTORY_SEPARATOR."adodb-hack".DIRECTORY_SEPARATOR."adodb.inc.php";
......
...@@ -27,7 +27,7 @@ ...@@ -27,7 +27,7 @@
* @version $Id$ * @version $Id$
*/ */
class Doctrine_DataDict_Sqlite { class Doctrine_DataDict_Sqlite extends Doctrine_DataDict {
/** /**
* lists all databases * lists all databases
* *
...@@ -79,6 +79,22 @@ class Doctrine_DataDict_Sqlite { ...@@ -79,6 +79,22 @@ class Doctrine_DataDict_Sqlite {
*/ */
public function listTableColumns($table) { public function listTableColumns($table) {
$sql = "PRAGMA table_info($table)";
$result = $this->dbh->query($sql)->fetchAll(PDO::FETCH_ASSOC);
$description = array();
$columns = array();
foreach ($result as $key => $val) {
$description = array(
'name' => $val['name'],
'type' => $val['type'],
'notnull' => (bool) $val['notnull'],
'default' => $val['dflt_value'],
'primary' => (bool) $val['pk'],
);
$columns[$val['name']] = new Doctrine_Schema_Column($description);
}
return $columns;
} }
/** /**
* lists table constraints * lists table constraints
...@@ -90,13 +106,17 @@ class Doctrine_DataDict_Sqlite { ...@@ -90,13 +106,17 @@ class Doctrine_DataDict_Sqlite {
} }
/** /**
* lists table constraints * lists tables
* *
* @param string|null $database * @param string|null $database
* @return array * @return array
*/ */
public function listTables($database = null) { public function listTables($database = null) {
$sql = "SELECT name FROM sqlite_master WHERE type='table' "
. "UNION ALL SELECT name FROM sqlite_temp_master "
. "WHERE type='table' ORDER BY name";
return $this->dbh->query($sql)->fetchAll(PDO::FETCH_ASSOC);
} }
/** /**
* lists table triggers * lists table triggers
......
...@@ -33,102 +33,43 @@ ...@@ -33,102 +33,43 @@
* class Doctrine_Schema_Column * class Doctrine_Schema_Column
* Holds information on a database table field * Holds information on a database table field
*/ */
class Doctrine_Schema_Column extends Doctrine_Schema_Object class Doctrine_Schema_Column extends Doctrine_Schema_Object implements IteratorAggregate {
implements IteratorAggregate
{
/** Aggregations: */
/** Compositions: */
var $m_Vector = array();
/*** Attributes: ***/
/**
* Column name
* @access public
*/
public $name;
/**
* Column type e.g. varchar, char, int etc.
* @access public
*/
public $type;
/**
* Field max length
* @access public
*/
public $length;
/**
* Is an autoincrement column
* @access public
*/
public $autoincrement;
/**
* Default field value
* @access public
*/
public $default;
/**
* Is not null
* @access public
*/
public $notNull;
/**
* Column comment
* @access public
*/
public $description;
/** /**
* Column level check constraint * column definitions
* @access public * @var array $definition
*/ */
public $check; private $definition = array('name' => '',
'type' => '',
/** 'unique' => false,
* Character encoding e.g. ISO-8859-1 or UTF-8 etc. 'primary' => false,
* @access public 'notnull' => false,
*/ 'default' => null,
public $charset; );
/** public function __construct(array $definition) {
* foreach($this->definition as $key => $val) {
* @return if(isset($definition[$key]))
* @access public $this->definition[$key] = $definition[$key];
*/ }
public function __toString( ) { }
public function getName() {
} // end of member function __toString return $this->definition['name'];
}
/** public function getType() {
* return $this->definition['type'];
* @return }
* @access public public function isUnique() {
*/ return $this->definition['unique'];
public function __clone( ) { }
public function isPrimaryKey() {
} // end of member function __clone return $this->definition['primary'];
}
/** public function defaultValue() {
* return $this->definition['default'];
* @return bool }
* @access public public function isNotNull() {
*/ return $this->definition['notnull'];
public function isValid( ) { }
} // end of member function isValid
} // end of Doctrine_Schema_Column } // end of Doctrine_Schema_Column
...@@ -360,6 +360,13 @@ class Doctrine_DB2 implements Countable, IteratorAggregate { ...@@ -360,6 +360,13 @@ class Doctrine_DB2 implements Countable, IteratorAggregate {
return $rows; return $rows;
} }
/**
* fetchAll
*/
public function fetchAssoc($statement, $params = array()) {
if( ! $params)
$this->query($statement);
}
/** /**
* lastInsertId * lastInsertId
* *
......
<?php
class Doctrine_DataDict_Sqlite_TestCase extends Doctrine_UnitTestCase {
private $dict;
private $columns;
public function prepareData() { }
public function prepareTables() {
$this->dbh->query("CREATE TABLE test (col_null NULL,
col_int INTEGER NOT NULL,
col_real REAL,
col_text TEXT DEFAULT 'default' NOT NULL,
col_blob BLOB)");
$this->dict = new Doctrine_DataDict_Sqlite($this->dbh);
$this->columns = $this->dict->listTableColumns('test');
}
public function testListTables() {
$result = $this->dict->listTables();
}
public function testIntegerType() {
$this->assertEqual($this->columns['col_int']->isUnique(), false);
$this->assertEqual($this->columns['col_int']->isNotNull(), true);
$this->assertEqual($this->columns['col_int']->defaultValue(), null);
$this->assertEqual($this->columns['col_int']->isPrimaryKey(), false);
$this->assertEqual($this->columns['col_int']->getType(), 'INTEGER');
$this->assertEqual($this->columns['col_int']->getName(), 'col_int');
}
public function testNullType() {
$this->assertEqual($this->columns['col_null']->isUnique(), false);
$this->assertEqual($this->columns['col_null']->isNotNull(), false);
$this->assertEqual($this->columns['col_null']->defaultValue(), null);
$this->assertEqual($this->columns['col_null']->isPrimaryKey(), false);
$this->assertEqual($this->columns['col_null']->getType(), 'numeric');
$this->assertEqual($this->columns['col_null']->getName(), 'col_null');
}
public function testTextType() {
$this->assertEqual($this->columns['col_text']->isUnique(), false);
$this->assertEqual($this->columns['col_text']->isNotNull(), true);
$this->assertEqual($this->columns['col_text']->defaultValue(), 'default');
$this->assertEqual($this->columns['col_text']->isPrimaryKey(), false);
$this->assertEqual($this->columns['col_text']->getType(), 'TEXT');
$this->assertEqual($this->columns['col_text']->getName(), 'col_text');
}
public function testBlobType() {
$this->assertEqual($this->columns['col_blob']->isUnique(), false);
$this->assertEqual($this->columns['col_blob']->isNotNull(), false);
$this->assertEqual($this->columns['col_blob']->defaultValue(), null);
$this->assertEqual($this->columns['col_blob']->isPrimaryKey(), false);
$this->assertEqual($this->columns['col_blob']->getType(), 'BLOB');
$this->assertEqual($this->columns['col_blob']->getName(), 'col_blob');
}
public function testRealType() {
$this->assertEqual($this->columns['col_real']->isUnique(), false);
$this->assertEqual($this->columns['col_real']->isNotNull(), false);
$this->assertEqual($this->columns['col_real']->defaultValue(), null);
$this->assertEqual($this->columns['col_real']->isPrimaryKey(), false);
$this->assertEqual($this->columns['col_real']->getType(), 'REAL');
$this->assertEqual($this->columns['col_real']->getName(), 'col_real');
}
}
?>
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment