123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187 |
- <?php
- namespace Tqdev\PhpCrudApi\Database;
-
- class TypeConverter
- {
- private $driver;
-
- public function __construct(String $driver)
- {
- $this->driver = $driver;
- }
-
- private $fromJdbc = [
- 'mysql' => [
- 'clob' => 'longtext',
- 'boolean' => 'bit',
- 'blob' => 'longblob',
- 'timestamp' => 'datetime',
- ],
- 'pgsql' => [
- 'clob' => 'text',
- 'blob' => 'bytea',
- ],
- 'sqlsrv' => [
- 'boolean' => 'bit',
- ],
- ];
-
- private $toJdbc = [
- 'simplified' => [
- 'char' => 'varchar',
- 'longvarchar' => 'clob',
- 'nchar' => 'varchar',
- 'nvarchar' => 'varchar',
- 'longnvarchar' => 'clob',
- 'binary' => 'varbinary',
- 'longvarbinary' => 'blob',
- 'tinyint' => 'integer',
- 'smallint' => 'integer',
- 'real' => 'float',
- 'numeric' => 'decimal',
- 'time_with_timezone' => 'time',
- 'timestamp_with_timezone' => 'timestamp',
- ],
- 'mysql' => [
- 'tinyint(1)' => 'boolean',
- 'bit(0)' => 'boolean',
- 'bit(1)' => 'boolean',
- 'tinyblob' => 'blob',
- 'mediumblob' => 'blob',
- 'longblob' => 'blob',
- 'tinytext' => 'clob',
- 'mediumtext' => 'clob',
- 'longtext' => 'clob',
- 'text' => 'clob',
- 'int' => 'integer',
- 'polygon' => 'geometry',
- 'point' => 'geometry',
- 'datetime' => 'timestamp',
- ],
- 'pgsql' => [
- 'bigserial' => 'bigint',
- 'bit varying' => 'bit',
- 'box' => 'geometry',
- 'bytea' => 'blob',
- 'character varying' => 'varchar',
- 'character' => 'char',
- 'cidr' => 'varchar',
- 'circle' => 'geometry',
- 'double precision' => 'double',
- 'inet' => 'integer',
- //'interval [ fields ]'
- 'jsonb' => 'clob',
- 'line' => 'geometry',
- 'lseg' => 'geometry',
- 'macaddr' => 'varchar',
- 'money' => 'decimal',
- 'path' => 'geometry',
- 'point' => 'geometry',
- 'polygon' => 'geometry',
- 'real' => 'float',
- 'serial' => 'integer',
- 'text' => 'clob',
- 'time without time zone' => 'time',
- 'time with time zone' => 'time_with_timezone',
- 'timestamp without time zone' => 'timestamp',
- 'timestamp with time zone' => 'timestamp_with_timezone',
- //'tsquery'=
- //'tsvector'
- //'txid_snapshot'
- 'uuid' => 'char',
- 'xml' => 'clob',
- ],
- // source: https://docs.microsoft.com/en-us/sql/connect/jdbc/using-basic-data-types?view=sql-server-2017
- 'sqlsrv' => [
- 'varbinary(0)' => 'blob',
- 'bit' => 'boolean',
- 'datetime' => 'timestamp',
- 'datetime2' => 'timestamp',
- 'float' => 'double',
- 'image' => 'longvarbinary',
- 'int' => 'integer',
- 'money' => 'decimal',
- 'ntext' => 'longnvarchar',
- 'smalldatetime' => 'timestamp',
- 'smallmoney' => 'decimal',
- 'text' => 'longvarchar',
- 'timestamp' => 'binary',
- 'tinyint' => 'tinyint',
- 'udt' => 'varbinary',
- 'uniqueidentifier' => 'char',
- 'xml' => 'longnvarchar',
- ],
- ];
-
- // source: https://docs.oracle.com/javase/9/docs/api/java/sql/Types.html
- private $valid = [
- //'array' => true,
- 'bigint' => true,
- 'binary' => true,
- 'bit' => true,
- 'blob' => true,
- 'boolean' => true,
- 'char' => true,
- 'clob' => true,
- //'datalink' => true,
- 'date' => true,
- 'decimal' => true,
- 'distinct' => true,
- 'double' => true,
- 'float' => true,
- 'integer' => true,
- //'java_object' => true,
- 'longnvarchar' => true,
- 'longvarbinary' => true,
- 'longvarchar' => true,
- 'nchar' => true,
- 'nclob' => true,
- //'null' => true,
- 'numeric' => true,
- 'nvarchar' => true,
- //'other' => true,
- 'real' => true,
- //'ref' => true,
- //'ref_cursor' => true,
- //'rowid' => true,
- 'smallint' => true,
- //'sqlxml' => true,
- //'struct' => true,
- 'time' => true,
- 'time_with_timezone' => true,
- 'timestamp' => true,
- 'timestamp_with_timezone' => true,
- 'tinyint' => true,
- 'varbinary' => true,
- 'varchar' => true,
- // extra:
- 'geometry' => true,
- ];
-
- public function toJdbc(String $type, int $size): String
- {
- $jdbcType = strtolower($type);
- if (isset($this->toJdbc[$this->driver]["$jdbcType($size)"])) {
- $jdbcType = $this->toJdbc[$this->driver]["$jdbcType($size)"];
- }
- if (isset($this->toJdbc[$this->driver][$jdbcType])) {
- $jdbcType = $this->toJdbc[$this->driver][$jdbcType];
- }
- if (isset($this->toJdbc['simplified'][$jdbcType])) {
- $jdbcType = $this->toJdbc['simplified'][$jdbcType];
- }
- if (!isset($this->valid[$jdbcType])) {
- throw new \Exception("Unsupported type '$jdbcType' for driver '$this->driver'");
- }
- return $jdbcType;
- }
-
- public function fromJdbc(String $type): String
- {
- $jdbcType = strtolower($type);
- if (isset($this->fromJdbc[$this->driver][$jdbcType])) {
- $jdbcType = $this->fromJdbc[$this->driver][$jdbcType];
- }
- return $jdbcType;
- }
- }
|