Server : nginx/1.20.2 System : Linux VM-4-4-centos 3.10.0-1160.66.1.el7.x86_64 #1 SMP Wed May 18 16:02:34 UTC 2022 x86_64 User : www ( 1000) PHP Version : 5.6.40 Disable Function : passthru,exec,system,putenv,chroot,chgrp,chown,shell_exec,popen,proc_open,pcntl_exec,ini_alter,ini_restore,dl,openlog,syslog,readlink,symlink,popepassthru,pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,imap_open,apache_setenv Directory : /www/wwwroot/greatapp.cn/vendor/topthink/think-migration/src/db/ |
<?php // +---------------------------------------------------------------------- // | ThinkPHP [ WE CAN DO IT JUST THINK IT ] // +---------------------------------------------------------------------- // | Copyright (c) 2016 http://thinkphp.cn All rights reserved. // +---------------------------------------------------------------------- // | Licensed ( http://www.apache.org/licenses/LICENSE-2.0 ) // +---------------------------------------------------------------------- // | Author: yunwuxin <448901948@qq.com> // +---------------------------------------------------------------------- namespace think\migration\db; use Phinx\Db\Adapter\AdapterInterface; use Phinx\Db\Adapter\MysqlAdapter; class Column extends \Phinx\Db\Table\Column { protected $unique = false; public function setNullable() { return $this->setNull(true); } public function setUnsigned() { return $this->setSigned(false); } public function setUnique() { $this->unique = true; return $this; } public function getUnique() { return $this->unique; } public function isUnique() { return $this->getUnique(); } public static function make($name, $type, $options = []) { $column = new self(); $column->setName($name); $column->setType($type); $column->setOptions($options); return $column; } public static function bigInteger($name) { return self::make($name, AdapterInterface::PHINX_TYPE_BIG_INTEGER); } public static function binary($name) { return self::make($name, AdapterInterface::PHINX_TYPE_BLOB); } public static function boolean($name) { return self::make($name, AdapterInterface::PHINX_TYPE_BOOLEAN); } public static function char($name, $length = 255) { return self::make($name, AdapterInterface::PHINX_TYPE_CHAR, compact('length')); } public static function date($name) { return self::make($name, AdapterInterface::PHINX_TYPE_DATE); } public static function dateTime($name) { return self::make($name, AdapterInterface::PHINX_TYPE_DATETIME); } public static function decimal($name, $precision = 8, $scale = 2) { return self::make($name, AdapterInterface::PHINX_TYPE_DECIMAL, compact('precision', 'scale')); } public static function enum($name, array $values) { return self::make($name, AdapterInterface::PHINX_TYPE_ENUM, compact('values')); } public static function float($name) { return self::make($name, AdapterInterface::PHINX_TYPE_FLOAT); } public static function integer($name) { return self::make($name, AdapterInterface::PHINX_TYPE_INTEGER); } public static function json($name) { return self::make($name, AdapterInterface::PHINX_TYPE_JSON); } public static function jsonb($name) { return self::make($name, AdapterInterface::PHINX_TYPE_JSONB); } public static function longText($name) { return self::make($name, AdapterInterface::PHINX_TYPE_TEXT, ['length' => MysqlAdapter::TEXT_LONG]); } public static function mediumInteger($name) { return self::make($name, AdapterInterface::PHINX_TYPE_INTEGER, ['length' => MysqlAdapter::INT_MEDIUM]); } public static function mediumText($name) { return self::make($name, AdapterInterface::PHINX_TYPE_TEXT, ['length' => MysqlAdapter::TEXT_MEDIUM]); } public static function smallInteger($name) { return self::make($name, AdapterInterface::PHINX_TYPE_INTEGER, ['length' => MysqlAdapter::INT_SMALL]); } public static function string($name, $length = 255) { return self::make($name, AdapterInterface::PHINX_TYPE_STRING, compact('length')); } public static function text($name) { return self::make($name, AdapterInterface::PHINX_TYPE_TEXT); } public static function time($name) { return self::make($name, AdapterInterface::PHINX_TYPE_TIME); } public static function tinyInteger($name) { return self::make($name, AdapterInterface::PHINX_TYPE_INTEGER, ['length' => MysqlAdapter::INT_TINY]); } public static function unsignedInteger($name) { return self::integer($name)->setUnSigned(); } public static function timestamp($name) { return self::make($name, AdapterInterface::PHINX_TYPE_TIMESTAMP); } public static function uuid($name) { return self::make($name, AdapterInterface::PHINX_TYPE_UUID); } }