Doctrine_DataDict_Sqlite driver
This commit is contained in:
parent
70ebe0d9af
commit
cec372dfe1
@ -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 @@
|
|||||||
*/
|
*/
|
||||||
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 @@
|
|||||||
* @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 {
|
|||||||
*/
|
*/
|
||||||
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 {
|
|||||||
|
|
||||||
}
|
}
|
||||||
/**
|
/**
|
||||||
* 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 @@
|
|||||||
* 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
|
* column definitions
|
||||||
* @access public
|
* @var array $definition
|
||||||
*/
|
*/
|
||||||
public $name;
|
private $definition = array('name' => '',
|
||||||
|
'type' => '',
|
||||||
/**
|
'unique' => false,
|
||||||
* Column type e.g. varchar, char, int etc.
|
'primary' => false,
|
||||||
* @access public
|
'notnull' => false,
|
||||||
*/
|
'default' => null,
|
||||||
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
|
|
||||||
* @access public
|
|
||||||
*/
|
|
||||||
public $check;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Character encoding e.g. ISO-8859-1 or UTF-8 etc.
|
|
||||||
* @access public
|
|
||||||
*/
|
|
||||||
public $charset;
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
*
|
|
||||||
* @return
|
|
||||||
* @access public
|
|
||||||
*/
|
|
||||||
public function __toString( ) {
|
|
||||||
|
|
||||||
} // end of member function __toString
|
|
||||||
|
|
||||||
/**
|
|
||||||
*
|
|
||||||
* @return
|
|
||||||
* @access public
|
|
||||||
*/
|
|
||||||
public function __clone( ) {
|
|
||||||
|
|
||||||
} // end of member function __clone
|
|
||||||
|
|
||||||
/**
|
|
||||||
*
|
|
||||||
* @return bool
|
|
||||||
* @access public
|
|
||||||
*/
|
|
||||||
public function isValid( ) {
|
|
||||||
|
|
||||||
} // end of member function isValid
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
public function __construct(array $definition) {
|
||||||
|
foreach($this->definition as $key => $val) {
|
||||||
|
if(isset($definition[$key]))
|
||||||
|
$this->definition[$key] = $definition[$key];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
public function getName() {
|
||||||
|
return $this->definition['name'];
|
||||||
|
}
|
||||||
|
public function getType() {
|
||||||
|
return $this->definition['type'];
|
||||||
|
}
|
||||||
|
public function isUnique() {
|
||||||
|
return $this->definition['unique'];
|
||||||
|
}
|
||||||
|
public function isPrimaryKey() {
|
||||||
|
return $this->definition['primary'];
|
||||||
|
}
|
||||||
|
public function defaultValue() {
|
||||||
|
return $this->definition['default'];
|
||||||
|
}
|
||||||
|
public function isNotNull() {
|
||||||
|
return $this->definition['notnull'];
|
||||||
|
}
|
||||||
} // end of Doctrine_Schema_Column
|
} // end of Doctrine_Schema_Column
|
||||||
|
|
||||||
|
@ -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
|
||||||
*
|
*
|
||||||
|
62
tests/DataDictSqliteTestCase.php
Normal file
62
tests/DataDictSqliteTestCase.php
Normal file
@ -0,0 +1,62 @@
|
|||||||
|
<?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');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
?>
|
Loading…
Reference in New Issue
Block a user