CI依据mysql数据库生成tablename枚举类

9 篇文章 0 订阅
<?php
/**
 * 加载字典
 * @author fzqyr
 *
 */

include APPPATH . 'enums/SystemEnum.php';
include APPPATH . 'enums/TableNames.php';

class LoadConfigBiz extends CI_Model
{

    public function __construct()
    {
        parent::__construct();
        $this->load->database();//加载数据库类
    }

    public function devLoadDbTable()
    {
        $strTableNames = '<?php';
        $strTableNames .= PHP_EOL;
        $strTableNames .= PHP_EOL . '/**
* 表名
* @author fzqyr
* ' . date( 'Y-m-d H:i:s', $_SERVER[ 'REQUEST_TIME' ] ) . PHP_EOL . '*/' .
                 PHP_EOL;
        
        $strTableNames .= 'class TableNames' . PHP_EOL . '{' . PHP_EOL;
        
        $tables = $this->db->list_tables();
        
        foreach( $tables as $table )
        {
            $strSQL = "show create table `$table`";
            
            $query = $this->db->query( $strSQL );
            $arr = $query->result_array();
            foreach( $arr as $t )
            {
                $str = $t[ 'Create Table' ];
                $str = substr( $str, strrpos( $str, ')' ) + 1 ) . PHP_EOL;
                
                $iPos = strpos( $str, 'COMMENT' );
                
                if( $iPos )
                {
                    $str = substr( $str, $iPos + strlen( 'COMMENT' ) + 1 );
                    $str = str_replace( '\'', '', $str );
                    $str = str_replace( '\r\n', PHP_EOL . "\t* ", $str );
                    
                    $strTableNames .= PHP_EOL;
                    
                    $strTableNames .= "\t/**" . PHP_EOL . "\t* ";
                    
                    $strTableNames .= ($str . "\t*/" . PHP_EOL);
                    
                    $strTableNames .= ("\tCONST " . strtoupper( $table ) .
                             " = '$table';" . PHP_EOL );
                
                }
                else
                {
                    $strTableNames .= ( PHP_EOL . "\tCONST " .
                             strtoupper( $table ) . " = '" . $table . "';" .
                             PHP_EOL);
                }
            
            }
        
        }
        
        $strTableNames .= PHP_EOL . '}' . PHP_EOL;
        
        file_put_contents( APPPATH . 'enums/TableNames.php', $strTableNames );
        
        echo 'generate tablenames success!';
    }

}

?>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值