12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849 |
- <?php
- use think\migration\Migrator;
- use think\migration\db\Column;
- use app\model\CustomerPortrait;
- class UpdateCustomerProtraitTableFamilyInfo extends Migrator
- {
- /**
- * Change Method.
- *
- * Write your reversible migrations using this method.
- *
- * More information on writing migrations is available here:
- * http://docs.phinx.org/en/latest/migrations.html#the-abstractmigration-class
- *
- * The following commands can be used in this method and Phinx will
- * automatically reverse them when rolling back:
- *
- * createTable
- * renameTable
- * addColumn
- * renameColumn
- * addIndex
- * addForeignKey
- *
- * Remember to call "create()" or "update()" and NOT "save()" when working
- * with the Table class.
- */
- public function change()
- {
- (new CustomerPortrait())->select()->each(function ($item){
- $content = json_decode($item['fields'], true);
- if (isset($content['family_info']['peripheral_supporting'])){
- $content['house_info']['peripheral_supporting'] = $content['family_info']['peripheral_supporting'];
- }
- if (isset($content['family_info']['consumption_capacity'])){
- $content['basic_info']['consumption_capacity'] = $content['family_info']['consumption_capacity'];
- }
- unset($content['family_info']['peripheral_supporting']);
- unset($content['family_info']['consumption_capacity']);
- unset($content['basic_info']['state']);
- unset($content['basic_info']['revisit_time']);
- $item->fields = json_encode($content);
- $item->save();
- });
- }
- }
|