http://blog.zol.com.cn/2210/article_2209590.html

/**
 * 分表程序
 *
 * @author Shen Xi shen.xi@zol.com.cn
 * @date 2010-08-19
 */
set_time_limit(0);
$con = mysql_connect("127.0.0.1","root","111111");#创建数据库连接
mysql_select_db ("test",$con);#选择连接数据库“test”
mysql_query("set names gbk");#设置获取数据得字符集

$slctTable = "tb_test";

#获取被分表结构
$sql = "show create table $slctTable";
$result = mysql_query($sql);
$row = mysql_fetch_array($result);
$createTable = $row['Create Table'];

//echo "$createStr
";

#获取被分表字段名
$field = mysql_list_fields("test",$slctTable,$con);
$filedNum = mysql_num_fields($field);
$fieldStr = "";
for($i=0;$i < $filedNum;$i++){
    $fieldStr.= "`". mysql_field_name($field, $i)."`,";
}
if(strlen($fieldStr) == 0){
    echo "获取表字段有误!";
    exit;
}
$fieldStr = "(".substr($fieldStr,0,-1).")";

//echo "$fieldStr
";
//exit;

#查找最大用户id
 $sql = "SELECT max(id) as maxid
         FROM  $slctTable";
 $result =mysql_query($sql);
 $row = mysql_fetch_row($result);
 
 $maxid = (int)$row[0];
// var_dump($maxid);
 //exit;
 if($maxid > 1){
     $count = ceil($maxid / 1000);
 }else{
     echo "用户最大id有误";
     exit;
 }
 $per = 500;#每次取得的记录条数
 $prefix = "tb_test";
 for($i=0;$i<=$count;$i++){
     
     $table = $prefix.$i;
    #生成创建新表的sql语句
    $createStr = str_replace("CREATE TABLE `$slctTable`","CREATE TABLE IF NOT EXISTS `$table`",$createTable);
    $filehandle = fopen ($table.".sql", "a+");
    fwrite($filehandle, $createStr."\r\n");
//    mysql_query($createStr);
     $sql="SELECT COUNT(*) AS num
             FROM $slctTable where CEILING(id / 1000)=$i";
    $result =mysql_query($sql);
    $row = mysql_fetch_row($result);
    
    $num = (int)$row[0];
     $maxNum= ceil((int)$num / $per);
     
     for($j=0;$j<$maxNum;$j++){
         $lmt = $j * $per;
         if($lmt <= (int)$num){
             $sql = "select * from $slctTable where CEILING(id / 1000)=$i order by id limit $lmt,500";
//             fwrite($filehandle, $sql."");
            $inStr="REPLACE INTO ".$table." ".$fieldStr." VALUES";
//            fwrite($filehandle, $inStr."\r\n");
            $result = mysql_query($sql);             
             if($result){
                 $value="";
                 while ($row = mysql_fetch_row($result)){
                     $value.= "(";
                     for($n=0;$n < $filedNum;$n++){
                         $value.="'".addslashes($row[$n])."',";
                     }
                     if(strlen($value)>2){
                         $value = substr($value,0,-1)."),\r\n";
                     }
                 }
                 if(strlen($value)>2){
                     $value = substr($value,0,-3)."";
                 }
                 $inStr = $inStr.$value;
//                 echo $inStr."\r\n";
//                 mysql_query($inStr);
                 fwrite($filehandle, $inStr);                 
             }
//             fclose($filehandle);
//             exit;
         }else{
             break;
         }
     }
     fclose($filehandle);

}

?>

PHP自动分表程序的更多相关文章

  1. 支持MySql的数据库自动分表工具DBShardTools发布

    支持MySql的数据库自动分表工具DBShardTools发布 前段时间参与了公司的一个项目,这个项目的特点是数据量.访问量都比较大,考虑使用数据库水平分表策略,Google了大半天,竟然没有找到分表 ...

  2. Mysql Event 自动分表

    create table TempComments Like dycomments; 上述 SQL语句创建的新表带有原表的所有属性,主键,索引等. 自动分表怎么做呢? 使用上述语句自动创建分表. 那么 ...

  3. 使用NLog把日志写入数据库并按天自动分表

    前言 最近用Asp.net Core开发程序的时候 因为时间的关系,就没有过多的去关注日志方面的功能 都是直接用系统的ILogger先记录着,然后看日志的时候就先在命令行看日志 在开发阶段没有什么问题 ...

  4. NPOI 导出excel数据超65535自动分表

    工作上遇到的问题,网上找了一些资料 整理了一个比较可行的解决方案. NPOI 大数据量分多个sheet导出 代码段 /// <summary> /// DataTable转换成Excel文 ...

  5. 基于efcore的分表组件开源

    ShardingCore ShardingCore 是一个支持efcore 2.x 3.x 5.x的一个对于数据库分表的一个简易扩展, 目前该库暂未支持分库(未来会支持),仅支持分表,该项目的理念是让 ...

  6. .NET 5 全自动分表组件,.NET 分表方案 ,分表架构与设计

    一.疑问&目的 1.1 分表使用场景 (1)可扩展架构设计,比如一个ERP用5年不卡,到了10就卡了因为数据太多了,这个时候很多人都是备份然后清空数据,这个工作大并且麻烦,以前的数据很难在使用 ...

  7. NPOI 导出excel 分表

    /// <summary> /// 由DataTable导出Excel[超出65536自动分表] /// </summary> /// <param name=" ...

  8. PostgreSQL 务实应用(三/5)分表复制

    问题的提出 在项目中,有些表的记录增长非常快,记录数过大时会使得查询变得困难,导致整个数据库处理性能下降.此时,我们会考虑按一定的规则进行分表存储. 常用的分表方式是按时间周期,如每月一张,每天一张等 ...

  9. tp5日志分表

    /** * 记录网站日志 * * @return bool */ public function record() { // 组装数据 $log = self::$param; $log[self:: ...

随机推荐

  1. Windows Azure存储容器私有,公共容器,公共Blob的区别

    当我们在Windows Azure中创建或编辑存储的容器时,需要选择访问类型,本文将描述一下这三个选项的区别. 1. 私有: 默认选项,顾名思义,用户不能通过URL匿名进行访问容器或容器内的任何Blo ...

  2. 扩展UIColor类

    在开发中,UI给出的颜色值有时候是十六进制的,有时候给出的是RGB(255,255,255)这样的形式的,而iOS系统提供的方法中并没有直接传递这两种值返回UIColor对象的,这里自己封装了一个以便 ...

  3. jquery获取显示器,屏幕的宽度,和高度

    Javascript: 网页可见区域宽: document.body.clientWidth网页可见区域高: document.body.clientHeight网页可见区域宽: document.b ...

  4. 【MySql】在Linux下安装MySql数据库

    [参数环境] 1.Host OS:Win7 64bit 2.VM: VMware 11.1.0 3.Client OS:CentOS 6 4.系统中已安装的openssl版本: openssl-1.0 ...

  5. Clean Code第二章<命名>

    1.命名要有意义 错误写法 正确写法 2.某些构造函数可以提供有意义的静态方法去实现

  6. 新 esb-cs-tool.jar 参数说明

    旧esb-cs-tool.jar 使用说明 : invoke(RequestBusinessObject requestBo) 旧参数说明: requestBo  : 封装好的请求参数大对象  Req ...

  7. spring mvc 数据绑定

    1.spring mvc 默认提供的数据绑定类 private List<HandlerMethodArgumentResolver> getDefaultArgumentResolver ...

  8. HDU2948Geometry Darts(简单计算几何)

    题目大意就是说两个人掷飞镖,飞镖在所给定的图形内就记一分,现在给定N个图形(圆.三角形和矩形),问每一次比赛(没人分别掷三次)谁赢. #include <map> #include < ...

  9. 欧几里德&扩展以及求解线性方程学习总结--附上poj1061解题报告

    欧几里德算法: 欧几里德就是辗转相除法,调用这个gcd(a,b)这个函数求解a,b的最大公约数 公式: gcd(a,b)=gcd(b,a%b):并且gcd(a,b)=gcd(b,a)=gcd(-a,b ...

  10. Castle IOC容器内幕故事(上)

    主要内容 1.WindsorContainer分析 2.MicroKernel分析 3.注册组件流程 一.WindsorContainer分析 WindsorContainer是Castle的IOC容 ...