1
0
mirror of https://github.com/dg/dibi.git synced 2025-08-05 05:37:39 +02:00

bug fixed

This commit is contained in:
David Grudl
2008-01-15 05:40:08 +00:00
parent 5c045e58dc
commit c41167d49f
12 changed files with 53 additions and 24 deletions

View File

@@ -227,7 +227,6 @@ class DibiMsSqlDriver extends NObject implements IDibiDriver
/**
* Returns the number of rows in a result set
*

View File

@@ -277,7 +277,6 @@ class DibiMySqlDriver extends NObject implements IDibiDriver
/**
* Returns the number of rows in a result set
*

View File

@@ -125,6 +125,7 @@ class DibiMySqliDriver extends NObject implements IDibiDriver
}
/**
* Disconnects from a database
*
@@ -256,8 +257,6 @@ class DibiMySqliDriver extends NObject implements IDibiDriver
/**
* Returns the number of rows in a result set
*

View File

@@ -239,7 +239,6 @@ class DibiOdbcDriver extends NObject implements IDibiDriver
/**
* Returns the number of rows in a result set
*

View File

@@ -232,7 +232,6 @@ class DibiOracleDriver extends NObject implements IDibiDriver
/**
* Returns the number of rows in a result set
*

View File

@@ -95,6 +95,7 @@ class DibiPdoDriver extends NObject implements IDibiDriver
}
/**
* Disconnects from a database
*

View File

@@ -69,6 +69,7 @@ class DibiPostgreDriver extends NObject implements IDibiDriver
}
/**
* Connects to a database
*
@@ -262,8 +263,6 @@ class DibiPostgreDriver extends NObject implements IDibiDriver
/**
* Returns the number of rows in a result set
*

View File

@@ -105,6 +105,7 @@ class DibiSqliteDriver extends NObject implements IDibiDriver
}
/**
* Disconnects from a database
*
@@ -235,7 +236,6 @@ class DibiSqliteDriver extends NObject implements IDibiDriver
/**
* Returns the number of rows in a result set
*

View File

@@ -49,6 +49,9 @@ abstract class DibiTable extends NObject
/** @var string primary key type */
protected $primaryModifier = '%i';
/** @var array */
protected $blankRow = array();
/**
* Table constructor
@@ -202,10 +205,10 @@ abstract class DibiTable extends NObject
if (!is_array($what)) {
$what = func_get_args();
}
return $this->connection->query(
return $this->complete($this->connection->query(
'SELECT * FROM %n', $this->name,
'WHERE %n', $this->primary, 'IN (' . $this->primaryModifier, $what, ')'
);
));
}
@@ -218,15 +221,15 @@ abstract class DibiTable extends NObject
public function findAll($order = NULL)
{
if ($order === NULL) {
return $this->connection->query(
return $this->complete($this->connection->query(
'SELECT * FROM %n', $this->name
);
));
} else {
$order = func_get_args();
return $this->connection->query(
return $this->complete($this->connection->query(
'SELECT * FROM %n', $this->name,
'ORDER BY %n', $order
);
));
}
}
@@ -235,14 +238,42 @@ abstract class DibiTable extends NObject
/**
* Fetches single row
* @param scalar primary key value
* @return array row
* @return array|object row
*/
public function fetch($what)
{
$this->connection->query(
return $this->complete($this->connection->query(
'SELECT * FROM %n', $this->name,
'WHERE %n', $this->primary, '=' . $this->primaryModifier, $what
)->fetch();
))->fetch();
}
/**
* Returns a blank row (not fetched from database)
* @return array|object
*/
public function createBlank()
{
$row = $this->blankRow;
$row[$this->primary] = NULL;
if ($this->connection->getConfig('result:objects')) {
$row = (object) $row;
}
return $row;
}
/**
* User DibiResult post-processing
* @param DibiResult
* @return DibiResult
*/
protected function complete($res)
{
return $res;
}
}

View File

@@ -39,6 +39,7 @@ class DibiVariable extends NObject implements IDibiVariable
}
public function toSql(IDibiDriver $driver, $modifier)
{
return $driver->format($this->value, $this->type);

View File

@@ -114,6 +114,7 @@ class NException extends Exception
}
/**
* Internal error handler
*/

View File

@@ -5,15 +5,17 @@
require_once '../dibi/dibi.php';
copy('sample.sdb', 'sample_tmp.sdb');
dibi::connect(array(
'driver' => 'sqlite',
'database' => 'sample_tmp.sdb',
'database' => 'sample.sdb',
));
dibi::begin();
// autodetection: primary keys are customer_id, order_id, ...
DibiTable::$primaryMask = '%s_id';
// table products
class Products extends DibiTable
@@ -24,8 +26,7 @@ class Products extends DibiTable
}
// autodetection: primary keys are customer_id, order_id, ...
DibiTable::$primaryMask = '%s_id';
@@ -38,7 +39,7 @@ echo "Primary key: $products->primary\n";
// Finds rows by primary key
foreach ($products->find(1, 3) as $row) {
...
print_r($row);
}