Viewing file: TimestampType.php (2.53 KB) -rw-r--r-- Select action/file-type: (+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
<?php
namespace Illuminate\Database\DBAL;
use Doctrine\DBAL\Exception as DBALException; use Doctrine\DBAL\Platforms\AbstractPlatform; use Doctrine\DBAL\Types\PhpDateTimeMappingType; use Doctrine\DBAL\Types\Type;
class TimestampType extends Type implements PhpDateTimeMappingType { /** * {@inheritdoc} */ public function getSQLDeclaration(array $fieldDeclaration, AbstractPlatform $platform) { return match ($name = $platform->getName()) { 'mysql', 'mysql2' => $this->getMySqlPlatformSQLDeclaration($fieldDeclaration), 'postgresql', 'pgsql', 'postgres' => $this->getPostgresPlatformSQLDeclaration($fieldDeclaration), 'mssql' => $this->getSqlServerPlatformSQLDeclaration($fieldDeclaration), 'sqlite', 'sqlite3' => $this->getSQLitePlatformSQLDeclaration($fieldDeclaration), default => throw new DBALException('Invalid platform: '.$name), }; }
/** * Get the SQL declaration for MySQL. * * @param array $fieldDeclaration * @return string */ protected function getMySqlPlatformSQLDeclaration(array $fieldDeclaration) { $columnType = 'TIMESTAMP';
if ($fieldDeclaration['precision']) { $columnType = 'TIMESTAMP('.$fieldDeclaration['precision'].')'; }
$notNull = $fieldDeclaration['notnull'] ?? false;
if (! $notNull) { return $columnType.' NULL'; }
return $columnType; }
/** * Get the SQL declaration for PostgreSQL. * * @param array $fieldDeclaration * @return string */ protected function getPostgresPlatformSQLDeclaration(array $fieldDeclaration) { return 'TIMESTAMP('.(int) $fieldDeclaration['precision'].')'; }
/** * Get the SQL declaration for SQL Server. * * @param array $fieldDeclaration * @return string */ protected function getSqlServerPlatformSQLDeclaration(array $fieldDeclaration) { return $fieldDeclaration['precision'] ?? false ? 'DATETIME2('.$fieldDeclaration['precision'].')' : 'DATETIME'; }
/** * Get the SQL declaration for SQLite. * * @param array $fieldDeclaration * @return string */ protected function getSQLitePlatformSQLDeclaration(array $fieldDeclaration) { return 'DATETIME'; }
/** * {@inheritdoc} */ public function getName() { return 'timestamp'; } }
|