2008-08-01 18:46:14 +00:00
|
|
|
<?php
|
|
|
|
|
2009-01-22 19:38:10 +00:00
|
|
|
namespace Doctrine\DBAL\Platforms;
|
2008-08-01 18:46:14 +00:00
|
|
|
|
2009-01-22 19:38:10 +00:00
|
|
|
class FirebirdPlatform extends AbstractPlatform
|
2008-08-01 18:46:14 +00:00
|
|
|
{
|
|
|
|
/**
|
|
|
|
* Constructor.
|
|
|
|
*/
|
|
|
|
public function __construct()
|
|
|
|
{
|
|
|
|
parent::__construct();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Adds an driver-specific LIMIT clause to the query
|
|
|
|
*
|
|
|
|
* @param string $query query to modify
|
|
|
|
* @param integer $limit limit the number of rows
|
|
|
|
* @param integer $offset start reading from given offset
|
|
|
|
* @return string modified query
|
|
|
|
* @override
|
|
|
|
*/
|
|
|
|
public function writeLimitClause($query, $limit, $offset)
|
|
|
|
{
|
|
|
|
if ( ! $offset) {
|
|
|
|
$offset = 0;
|
|
|
|
}
|
|
|
|
if ($limit > 0) {
|
|
|
|
$query = preg_replace('/^([\s(])*SELECT(?!\s*FIRST\s*\d+)/i',
|
|
|
|
"SELECT FIRST $limit SKIP $offset", $query);
|
|
|
|
}
|
|
|
|
return $query;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* return string for internal table used when calling only a function
|
|
|
|
*
|
|
|
|
* @return string for internal table used when calling only a function
|
|
|
|
*/
|
|
|
|
public function getFunctionTableExpression()
|
|
|
|
{
|
|
|
|
return ' FROM RDB$DATABASE';
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* build string to define escape pattern string
|
|
|
|
*
|
|
|
|
* @return string define escape pattern
|
|
|
|
* @override
|
|
|
|
*/
|
|
|
|
public function getPatternEscapeStringExpression()
|
|
|
|
{
|
|
|
|
return " ESCAPE '". $this->_properties['escape_pattern'] ."'";
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Obtain DBMS specific SQL code portion needed to set the CHARACTER SET
|
|
|
|
* of a field declaration to be used in statements like CREATE TABLE.
|
|
|
|
*
|
|
|
|
* @param string $charset name of the charset
|
|
|
|
* @return string DBMS specific SQL code portion needed to set the CHARACTER SET
|
|
|
|
* of a field declaration.
|
|
|
|
*/
|
|
|
|
public function getCharsetFieldDeclaration($charset)
|
|
|
|
{
|
|
|
|
return 'CHARACTER SET ' . $charset;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Obtain DBMS specific SQL code portion needed to set the COLLATION
|
|
|
|
* of a field declaration to be used in statements like CREATE TABLE.
|
|
|
|
*
|
|
|
|
* @param string $collation name of the collation
|
|
|
|
* @return string DBMS specific SQL code portion needed to set the COLLATION
|
|
|
|
* of a field declaration.
|
|
|
|
*/
|
|
|
|
public function getCollationFieldDeclaration($collation)
|
|
|
|
{
|
|
|
|
return 'COLLATE ' . $collation;
|
|
|
|
}
|
2009-05-28 21:34:35 +00:00
|
|
|
|
2008-09-07 13:48:40 +00:00
|
|
|
public function getSequenceNextValSql($sequenceName)
|
|
|
|
{
|
|
|
|
return 'SELECT GEN_ID(' . $this->quoteIdentifier($sequenceName) . ', 1) FROM RDB$DATABASE';
|
|
|
|
}
|
2009-05-28 21:34:35 +00:00
|
|
|
|
2008-09-12 17:25:38 +00:00
|
|
|
protected function _getTransactionIsolationLevelSql($level)
|
|
|
|
{
|
|
|
|
switch ($level) {
|
|
|
|
case Doctrine_DBAL_Connection::TRANSACTION_READ_UNCOMMITTED:
|
|
|
|
return 'READ COMMITTED RECORD_VERSION';
|
|
|
|
case Doctrine_DBAL_Connection::TRANSACTION_READ_COMMITTED:
|
|
|
|
return 'READ COMMITTED NO RECORD_VERSION';
|
|
|
|
case Doctrine_DBAL_Connection::TRANSACTION_REPEATABLE_READ:
|
|
|
|
return 'SNAPSHOT';
|
|
|
|
case Doctrine_DBAL_Connection::TRANSACTION_SERIALIZABLE:
|
|
|
|
return 'SNAPSHOT TABLE STABILITY';
|
|
|
|
default:
|
|
|
|
return parent::_getTransactionIsolationLevelSql($level);
|
|
|
|
}
|
|
|
|
}
|
2009-05-28 21:34:35 +00:00
|
|
|
|
2008-09-12 17:25:38 +00:00
|
|
|
public function getSetTransactionIsolationSql($level)
|
|
|
|
{
|
|
|
|
return 'SET TRANSACTION ISOLATION LEVEL ' . $this->_getTransactionIsolationLevelSql($level);
|
|
|
|
}
|
2009-05-27 18:54:40 +00:00
|
|
|
|
|
|
|
public function getName()
|
|
|
|
{
|
|
|
|
return 'firebird';
|
|
|
|
}
|
2009-02-20 05:46:20 +00:00
|
|
|
}
|