composer require topthink/think-migration
//执行命令,创建一个操作文件,一定要用大驼峰写法,如下
php think migrate:create AnyClassNameYouWant
//执行完成后,会在项目根目录多一个database目录,这里面存放类库操作文件
//文件名类似/database/migrations/20190615151716_any_class_name_you_want.php
table('users',array('engine'=>'MyISAM'));$table->addColumn('username', 'string',array('limit' => 15,'default'=>'','comment'=>'用户名,登陆使用'))->addColumn('password', 'string',array('limit' => 32,'default'=>md5('123456'),'comment'=>'用户密码')) ->addColumn('login_status', 'boolean',array('limit' => 1,'default'=>0,'comment'=>'登陆状态'))->addColumn('login_code', 'string',array('limit' => 32,'default'=>0,'comment'=>'排他性登陆标识'))->addColumn('last_login_ip', 'integer',array('limit' => 11,'default'=>0,'comment'=>'最后登录IP'))->addColumn('last_login_time', 'datetime',array('default'=>0,'comment'=>'最后登录时间'))->addColumn('is_delete', 'boolean',array('limit' => 1,'default'=>0,'comment'=>'删除状态,1已删除'))->addIndex(array('username'), array('unique' => true))->create();}}
php think migrate:run
选项 | 描述 |
---|---|
comment | 给表结构设置文本注释 |
row_format | 设置行记录模格式 |
engine | 表引擎 (默认 InnoDB ) |
collation | 表字符集 (默认 utf8\_general\_ci ) |
signed | 是否无符号 signed (默认 true ) |
Option | Description |
---|---|
limit | 文本或者整型的长度 |
length | limit 别名 |
default | 默认值 |
null | 允许 NULL 值 (不该给主键设置 |
after | 在哪个字段名后 (只对MySQL有效) |
comment | 给列设置文本注释 |
->addIndex(['email','username'], ['limit' => ['email' => 5, 'username' => 2]])->addIndex('user_guid', ['limit' => 6])->addIndex('email',['type'=>'fulltext'])
如上面例子所示,默认是普通索引
,mysql可设置生效复合索引
,mysql可以设置fulltext
.
该项目可以升级和还原,就像git/svn一样rollback。
如果希望实现自动升级降级,那就把逻辑写在change方法里,只最终调用create
和update
方法,不要调用save
方法。
change
方法内仅支持以下操作
如果真的有调用其他方法,可以写到up
和down
方法里,这里的逻辑不支持自动还原,up写升级的逻辑,down写降级的逻辑。
public function change(){// create the table$table = $this->table('user_logins');$table->addColumn('user_id', 'integer')->addColumn('created', 'datetime')->create();}/*** Migrate Up.*/public function up(){}/*** Migrate Down.*/public function down(){}
上一篇:SSRF漏洞 | iwebsec
下一篇:服务异步通信 RabbitMQ