命令行实战

2020-09-06  本文已影响0人  dongdog
<?php
/**
 * 创建表格
 * Created by PhpStorm.
 * User: Administrator
 * Date: 2020/9/5
 * Time: 21:50
 */

namespace app\index\command;

use think\console\Command;
use think\console\Input;
use think\console\input\Argument;
use think\console\Output;
use think\Db;

class CreateLogTable extends Command
{


    private $db;
    private $dateYmd;

    /**
     * 配置方法
     */
    protected function configure()
    {
        //给php think CreateTable 注册备注
        $this->setName('CreateLogTable')
            ->setDescription('创建日志表命令')/**
             * 定义形参
             * Argument::REQUIRED = 1; 必选
             * Argument::OPTIONAL = 2;  可选
             */
            ->addArgument('cronTab', Argument::OPTIONAL, '是否是定时任务')
            ->addArgument('start_date', Argument::OPTIONAL, '开始日期:格式2012-12-12')
            ->addArgument('end_date', Argument::OPTIONAL, '结束日期')// 运行 "php think list" 时的简短描述
            ->setDescription('创建表格')// 运行命令时使用 "--help | -h" 选项时的完整命令描述
            ->setHelp("当不给开始结束时间,默认只跑当天;\n只给了开始时间,跑指定的一天;\n给了开始和结束时间,跑指定范围内所有数据;");
    }

    const LOG_LIST = [
        //登陆 和 注册 都是总表 一张
        "tbl_gold_log_"               => [
            'name'      => '金币日志',
            'index_sql' => "KEY `game` (`role_id`,`p3`,`esrc`,`date`),
                KEY `activity` (`role_id`,`esrc`,`ps1`),
                KEY `role_date` (`role_id`,`date`)" //这是索引sql
        ],
        "tbl_exp_log_"                => [
            'name'      => '经验日志',
            'index_sql' => "KEY `role_date` (`role_id`,`date`)" //无索引
        ],
        "tbl_vip_exp_log_"            => [
            'name'      => 'vip经验日志',
            'index_sql' => "KEY `role_date` (`role_id`,`date`)" //无索引
        ],
        "tbl_exp_buff_log_"           => [
            'name'      => '经验buff日志',
            'index_sql' => "KEY `role_date` (`role_id`,`date`)" //无索引
        ],
        "tbl_upgrade_bonus_buff_log_" => [
            'name'      => '等级奖励buff日志',
            'index_sql' => "KEY `role_date` (`role_id`,`date`)" //无索引
        ],
        "tbl_room_log_"               => [
            'name'      => '房间日志',
            'index_sql' => "KEY `role_date` (`role_id`,`date`)" //无索引
        ],
        "tbl_prop_log_"               => [
            'name'      => '道具获得日志',
            'index_sql' => "KEY `role_date` (`role_id`,`date`)" //无索引
        ],
        "tbl_email_log_"              => [
            'name'      => '个人邮件日志',
            'index_sql' => "KEY `role_date` (`role_id`,`date`)" //无索引
        ],
    ];


    /**
     *     * 生成所需的数据表
     * php think test  调用的方法
     *
     * @param Input  $input  接收参数对象
     * @param Output $output 操作命令
     *
     * @return int|null|void
     * @throws \think\Exception
     */
    protected function execute(Input $input, Output $output)
    {
        //数据库连接
        $this->db = Db::connect('database.log');


        //是定时任务
        if (!empty($input->getArgument('cronTab'))) {
            //生成明天的日志
            $this->dateYmd = date('Ymd', strtotime('tomorrow'));
            $output->writeln("---{$this->dateYmd}日定时任务开始---");
            //遍历生成日志
            foreach (self::LOG_LIST as $table => $value) {
                //判断表表不存在
                $exist = $this->db->query("show tables like '{$table}{$this->dateYmd}'");
                if (empty($exist)) {
                    $createTableSql = $this->getCreateLogsSql($table . $this->dateYmd, $value);
                    //生成各种日志表
                    $this->db->execute($createTableSql);
                    $output->writeln("---{$table}{$this->dateYmd}:日志表生成成功---");
                }
            }
            $output->writeln("---本次定时任务结束---");
            exit;
        }
        //获取传输的时间
        $start_date = $input->getArgument('start_date');
        $end_date   = $input->getArgument('end_date');
        if (empty($start_date) || empty($end_date)) {
            $output->writeln("---start_date或者end_date未传入---");
            exit;
        }
        while ($start_date <= $end_date) {
            //循环生成报表
            foreach (self::LOG_LIST as $table => $message) {
                //日志日期充值
                $this->dateYmd = date('Ymd', strtotime($start_date));
                //判断表表不存在
                $exist = $this->db->query("show tables like '{$table}{$this->dateYmd}'");
                //如果不存在
                if (empty($exist)) {
                    $createTableSql = $this->getCreateLogsSql($table . $this->dateYmd, $message, $table);
                    //生成各种日志表
                    $this->db->execute($createTableSql);
                    $output->writeln("---{$table}{$this->dateYmd}日志生成---");
                }
            }
            $start_date = date('Y-m-d', strtotime("+1 day", strtotime($start_date)));
        }
        $output->writeln("---本次定时任务结束---");
    }

    /**
     * 获取各种子报表的sql
     *
     * @param array  $info
     * @param string $tableName
     *
     * @return string
     */
    private function getCreateLogsSql(string $tableName, array $info)
    {
        return "
        CREATE TABLE `{$tableName}` (
          `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT,
          `date` datetime DEFAULT NULL,
          `sid` int(11) unsigned NOT NULL DEFAULT '0' COMMENT '服务器id,为0表示来源未知',
          `roleid`  int(11) unsigned NOT NULL DEFAULT '0' COMMENT '服务器id-角色id,为0表示系统事件 角色id不唯一',
          `eid` int(11) unsigned NOT NULL DEFAULT '0' COMMENT '事件id 大分类',
          `esrc` int(11) unsigned DEFAULT '0' COMMENT '事件来源 子分类',
          `p1` bigint(20) DEFAULT '0' COMMENT '参数1',
          `p2` bigint(20) DEFAULT '0' COMMENT '参数2',
          `p3` bigint(20) DEFAULT '0' COMMENT '参数3',
          `p4` bigint(20) unsigned DEFAULT '0' COMMENT '参数4',
          `p5` bigint(20) DEFAULT '0' COMMENT '参数5',
          `p6` bigint(20) DEFAULT '0' COMMENT '参数6',
          `ps1` varchar(1024) DEFAULT NULL COMMENT '字符串参数1',
          `ps2` varchar(1024) DEFAULT NULL COMMENT '字符串参数2',
          `ps3` varchar(1024) DEFAULT NULL COMMENT '字符串参数3',
          PRIMARY KEY (`id`)
          {$info['index_sql']}
    ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='{$info['name']}';
        ";

    }


}

命令行调用 php 执行think 脚本名 参数1 参数2 参数3

php /www/wwwroot/newCenter/think CreateLogTable 0 2020-09-01 2020-09-06

上一篇 下一篇

猜你喜欢

热点阅读