ColumnSchema.php 5.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192
  1. <?php
  2. /**
  3. * @link https://www.yiiframework.com/
  4. * @copyright Copyright (c) 2008 Yii Software LLC
  5. * @license https://www.yiiframework.com/license/
  6. */
  7. namespace yii\db;
  8. use yii\base\BaseObject;
  9. use yii\helpers\StringHelper;
  10. /**
  11. * ColumnSchema class describes the metadata of a column in a database table.
  12. *
  13. * @author Qiang Xue <qiang.xue@gmail.com>
  14. * @since 2.0
  15. */
  16. class ColumnSchema extends BaseObject
  17. {
  18. /**
  19. * @var string name of this column (without quotes).
  20. */
  21. public $name;
  22. /**
  23. * @var bool whether this column can be null.
  24. */
  25. public $allowNull;
  26. /**
  27. * @var string abstract type of this column. Possible abstract types include:
  28. * char, string, text, boolean, smallint, integer, bigint, float, decimal, datetime,
  29. * timestamp, time, date, binary, and money.
  30. */
  31. public $type;
  32. /**
  33. * @var string the PHP type of this column. Possible PHP types include:
  34. * `string`, `boolean`, `integer`, `double`, `array`.
  35. */
  36. public $phpType;
  37. /**
  38. * @var string the DB type of this column. Possible DB types vary according to the type of DBMS.
  39. */
  40. public $dbType;
  41. /**
  42. * @var mixed default value of this column
  43. */
  44. public $defaultValue;
  45. /**
  46. * @var array enumerable values. This is set only if the column is declared to be an enumerable type.
  47. */
  48. public $enumValues;
  49. /**
  50. * @var int display size of the column.
  51. */
  52. public $size;
  53. /**
  54. * @var int precision of the column data, if it is numeric.
  55. */
  56. public $precision;
  57. /**
  58. * @var int scale of the column data, if it is numeric.
  59. */
  60. public $scale;
  61. /**
  62. * @var bool whether this column is a primary key
  63. */
  64. public $isPrimaryKey;
  65. /**
  66. * @var bool whether this column is auto-incremental
  67. */
  68. public $autoIncrement = false;
  69. /**
  70. * @var bool whether this column is unsigned. This is only meaningful
  71. * when [[type]] is `smallint`, `integer` or `bigint`.
  72. */
  73. public $unsigned;
  74. /**
  75. * @var string comment of this column. Not all DBMS support this.
  76. */
  77. public $comment;
  78. /**
  79. * Converts the input value according to [[phpType]] after retrieval from the database.
  80. * If the value is null or an [[Expression]], it will not be converted.
  81. * @param mixed $value input value
  82. * @return mixed converted value
  83. */
  84. public function phpTypecast($value)
  85. {
  86. return $this->typecast($value);
  87. }
  88. /**
  89. * Converts the input value according to [[type]] and [[dbType]] for use in a db query.
  90. * If the value is null or an [[Expression]], it will not be converted.
  91. * @param mixed $value input value
  92. * @return mixed converted value. This may also be an array containing the value as the first element
  93. * and the PDO type as the second element.
  94. */
  95. public function dbTypecast($value)
  96. {
  97. // the default implementation does the same as casting for PHP, but it should be possible
  98. // to override this with annotation of explicit PDO type.
  99. return $this->typecast($value);
  100. }
  101. /**
  102. * Converts the input value according to [[phpType]] after retrieval from the database.
  103. * If the value is null or an [[Expression]], it will not be converted.
  104. * @param mixed $value input value
  105. * @return mixed converted value
  106. * @since 2.0.3
  107. */
  108. protected function typecast($value)
  109. {
  110. if ($value === ''
  111. && !in_array(
  112. $this->type,
  113. [
  114. Schema::TYPE_TEXT,
  115. Schema::TYPE_STRING,
  116. Schema::TYPE_BINARY,
  117. Schema::TYPE_CHAR
  118. ],
  119. true)
  120. ) {
  121. return null;
  122. }
  123. if ($value === null
  124. || gettype($value) === $this->phpType
  125. || $value instanceof ExpressionInterface
  126. || $value instanceof Query
  127. ) {
  128. return $value;
  129. }
  130. if (is_array($value)
  131. && count($value) === 2
  132. && isset($value[1])
  133. && in_array($value[1], $this->getPdoParamTypes(), true)
  134. ) {
  135. return new PdoValue($value[0], $value[1]);
  136. }
  137. switch ($this->phpType) {
  138. case 'resource':
  139. case 'string':
  140. if (is_resource($value)) {
  141. return $value;
  142. }
  143. if (is_float($value)) {
  144. // ensure type cast always has . as decimal separator in all locales
  145. return StringHelper::floatToString($value);
  146. }
  147. if (is_numeric($value)
  148. && ColumnSchemaBuilder::CATEGORY_NUMERIC === ColumnSchemaBuilder::$typeCategoryMap[$this->type]
  149. ) {
  150. // https://github.com/yiisoft/yii2/issues/14663
  151. return $value;
  152. }
  153. if (PHP_VERSION_ID >= 80100 && is_object($value) && $value instanceof \BackedEnum) {
  154. return (string) $value->value;
  155. }
  156. return (string) $value;
  157. case 'integer':
  158. if (PHP_VERSION_ID >= 80100 && is_object($value) && $value instanceof \BackedEnum) {
  159. return (int) $value->value;
  160. }
  161. return (int) $value;
  162. case 'boolean':
  163. // treating a 0 bit value as false too
  164. // https://github.com/yiisoft/yii2/issues/9006
  165. return (bool) $value && $value !== "\0";
  166. case 'double':
  167. return (float) $value;
  168. }
  169. return $value;
  170. }
  171. /**
  172. * @return int[] array of numbers that represent possible PDO parameter types
  173. */
  174. private function getPdoParamTypes()
  175. {
  176. return [\PDO::PARAM_BOOL, \PDO::PARAM_INT, \PDO::PARAM_STR, \PDO::PARAM_LOB, \PDO::PARAM_NULL, \PDO::PARAM_STMT];
  177. }
  178. }