登录
首页 >  数据库 >  MySQL

PHP 若Mysql单表存在数据量过大,进行逻辑分表

来源:SegmentFault

时间:2023-01-23 20:26:53 456浏览 收藏

本篇文章给大家分享《PHP 若Mysql单表存在数据量过大,进行逻辑分表》,覆盖了数据库的常见基础知识,其实一个语言的全部知识点一篇文章是不可能说完的,但希望通过这些问题,让读者对自己的掌握程度有一定的认识(B 数),从而弥补自己的不足,更好的掌握它。

假设数据库存在一个log表,用于记录用户操作系统的使用记录。
有如下字段
user_id 操作人id
record_time 操作时间
operate_type 操作类型
record_content 操作内容

QQ截图20200312174104.png

这个单表情况下,若日积月累的情况下,数据会逐日增多,最终达到百万行的情况,这个时候如果是查询表数据,会很慢。
于是,在PHP开发中可以在插入数据之前进行逻辑处理,并将单表分割成多个表。

原理

以日志表做示例。
根据当前时间的年月做基础,使用PHP动态创建表,达到在2020-03月存储的数据在log_2020_03表中,而2020-04月存储的日志在log_2020_04表中

QQ截图20200312182138.png

PHP代码

connect( '127.0.0.1', '6379' );    //redis服务器地址和端口
        $redis->auth( 'password' );                //redis密码
        $redis->select( 'db' );                    //选择redis库

        //log表名按照按照 'log_年_月'的规则
        $ruleTable = 'log_' . date('Y-m');

        $isExist = $redis->exists($ruleTable);    //检测redis中是否有log表的标志
        //若redis查询时未发现log表的标志,则动态创建log表
        if ( !$isExist ) {
            $sql = "CREATE TABLE `{$ruleTable}` (
                 `user_id` int(10) NOT NULL,
                 `record_time` datetime NOT NULL,
                 `operate_type` tinyint(10) NOT NULL,
                 `record_content` varchar(20) COLLATE utf8_unicode_ci NOT NULL
                ) ENGINE=MyISAM DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci";
            //执行mysql 此处省略数据库连接代码
            $result = mysqli_query($sql);
            //并记录log表标志到redis中
            $redis->setex($ruleTable,-1,1);        //redis key位'log_年_月' 永久不过期 值为1
        }
        /**
         * 插入记录数据
         */
        $sql = "INSERT INTO `log` (`user_id`, `record_time`, `operate_type`, `record_content`) 
                VALUES ('{$userId}', '{$time}, '{$typeId}', '{$content}')";
        //执行mysql 此处省略数据库连接代码
        $result = mysqli_query($sql);
        //关闭redis连接
        $redis->close();
    }
}
Log::getInstance()->record( 1,10,'随便记录',date('Y-m-d H:i:s') );

理论要掌握,实操不能落!以上关于《PHP 若Mysql单表存在数据量过大,进行逻辑分表》的详细介绍,大家都掌握了吧!如果想要继续提升自己的能力,那么就来关注golang学习网公众号吧!

声明:本文转载于:SegmentFault 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>
评论列表