찾다
백엔드 개발PHP 튜토리얼php实例之mysql数据备份_PHP教程

本代码实现了表结构和数据完全分开,默认有一个文件会记录所有表的结构,然后表中数据的备份 如果超过分卷的大小则会分成多个文件,不然则一个文件

备份:表结构和数据完全分开,默认有一个文件会记录所有表的结构,然后表中数据的备份 如果超过分卷的大小则会分成多个文件,不然则一个文件,参考了别人的代码,不过写的嘛,差强 人意,以后慢慢改吧。。。

代码如下:

<?<span>php

</span><span>/*</span><span>
 * Created on 2014
 * Link for 527891885@qq.com
 * This is seocheck backup class
 </span><span>*/</span>
<span>class</span><span> DbBackUp {
    </span><span>private</span> <span>$conn</span><span>;
    </span><span>private</span> <span>$dbName</span><span>;
    </span><span>private</span> <span>$host</span><span>;
    </span><span>private</span> <span>$tag</span> = '_b'<span>;
    </span><span>//</span><span>构造方法 链接数据库</span>
    <span>public</span> <span>function</span> __construct(<span>$host</span>='localhost', <span>$dbUser</span>='root', <span>$dbPwd</span>='', <span>$dbName</span>="seocheck", <span>$charset</span>='utf8'<span>) {
        @</span><span>ob_start</span><span>();
        @</span><span>set_time_limit</span>(0<span>);
        </span><span>$this</span>->conn = <span>mysql_connect</span>(<span>$host</span>, <span>$dbUser</span>, <span>$dbPwd</span>, <span>true</span><span>);
        </span><span>if</span>(!<span>$this</span>->conn) <span>die</span>("数据库系统连接失败!"<span>);
        </span><span>mysql_query</span>("set names ".<span>$charset</span>, <span>$this</span>-><span>conn);
        </span><span>mysql_select_db</span>(<span>$dbName</span>, <span>$this</span>->conn) or <span>die</span>("数据库连接失败!"<span>);
        </span><span>$this</span>->host = <span>$host</span><span>;
        </span><span>$this</span>->dbName = <span>$dbName</span><span>;
    }
 

    </span><span>//</span><span>获取数据库所有表名</span>
    <span>public</span> <span>function</span><span> getTableNames () {
        </span><span>$tables</span> = <span>array</span><span>();
        </span><span>$result</span> = <span>mysql_list_tables</span>(<span>$this</span>->dbName, <span>$this</span>-><span>conn);
        </span><span>if</span>(!<span>$result</span>) <span>die</span>('MySQL Error: ' . <span>mysql_error</span><span>());
        </span><span>while</span>(<span>$row</span> = <span>mysql_fetch_row</span>(<span>$result</span><span>)) {
            </span><span>$tables</span>[] = <span>$row</span>[0<span>];
        }
        </span><span>return</span> <span>$tables</span><span>;
    }

    </span><span>//</span><span>获取数据库表的字段信息</span>
    <span>public</span> <span>function</span> getFieldsByTable (<span>$table</span><span>) {
        </span><span>$fields</span> = <span>array</span><span>();
        </span><span>$str</span> = ''<span>;
        </span><span>$res</span> = <span>mysql_query</span>("SHOW CREATE TABLE `{<span>$table</span>}`", <span>$this</span>-><span>conn);
        </span><span>if</span>(!<span>$res</span>) <span>die</span>('MySQL Error: ' . <span>mysql_error</span><span>());
        </span><span>while</span>(<span>$rows</span> = <span>mysql_fetch_assoc</span>(<span>$res</span><span>)) {
            </span><span>$str</span> = <span>str_replace</span>("CREATE TABLE `{<span>$table</span>}` (", "", <span>$rows</span>['Create Table']);<span>//</span><span>DROP TABLE IF EXISTS `{$table}`\n</span>
            <span>$str</span> = "--\n-- Table structure for table `{<span>$table</span>}`\n--\n\nCREATE TABLE IF NOT EXISTS `{<span>$table</span>}` ( ".<span>$str</span><span>;
            </span><span>$str</span> = <span>str_replace</span>(",", ", ", <span>$str</span><span>);
            </span><span>$str</span> = <span>str_replace</span>("`) ) ENGINE=InnoDB ", "`)\n ) ENGINE=InnoDB ", <span>$str</span><span>);
            </span><span>$str</span> .=";\n\n"<span>;
            </span><span>//</span><span>$str = $str.";\n\n--\n-- Dumping data for table `{$table}`\n--\n\n";</span>
            <span>$fields</span>[<span>$rows</span>['Table']] = <span>$str</span><span>;
        }
        </span><span>return</span> <span>$fields</span><span>;
    } www</span>.jbxue.<span>com

    </span><span>//</span><span>获取表中的数据</span>
    <span>public</span> <span>function</span> getDataByTable(<span>$table</span><span>) {
        </span><span>$data</span> = <span>array</span><span>();
        </span><span>$str</span> = ''<span>;
        </span><span>$res</span> = <span>mysql_query</span>("SELECT * FROM `{<span>$table</span>}`", <span>$this</span>-><span>conn);
        </span><span>if</span>(!<span>$res</span>) <span>die</span>('MySQL Error: ' . <span>mysql_error</span><span>());
        </span><span>while</span>(<span>$rows</span> = <span>mysql_fetch_assoc</span>(<span>$res</span><span>)) {
            </span><span>if</span>(!<span>empty</span>(<span>$rows</span><span>)) {
                </span><span>$data</span>[] = <span>$rows</span><span>;
            }
        }
        </span><span>$keys</span> = <span>array_keys</span>(<span>$data</span>[0<span>]);
        </span><span>foreach</span> (<span>$keys</span> <span>as</span> <span>$k</span>=><span>$v</span><span>) {
            </span><span>$keys</span>[<span>$k</span>] = '`'.<span>$v</span>.'`'<span>;
        }
        </span><span>$key</span> = <span>join</span>(', ', <span>$keys</span><span>);
        </span><span>$str</span> = "INSERT INTO `{<span>$table</span>}` ({<span>$key</span>}) VALUES\n"<span>;
        </span><span>foreach</span> (<span>$data</span> <span>as</span> <span>$k</span>=><span>$v</span><span>) {
            </span><span>$str</span>.="("<span>;
            </span><span>while</span> (<span>list</span>(<span>$key</span>, <span>$val</span>) = <span>each</span>(<span>$v</span><span>)) {
                </span><span>if</span>(!<span>is_numeric</span>(<span>$val</span><span>)) {
                    </span><span>$str</span>.= "'".<span>$val</span>."', "<span>;
                } </span><span>else</span><span> {
                    </span><span>$str</span>.= <span>$val</span>.', '<span>;
                }
            }
            </span><span>$str</span> = <span>substr</span>(<span>$str</span>, 0, -2);<span>//</span><span> 后边有空格 所以从-2 开始截取</span>
            <span>if</span>(<span>$k</span>+1 == <span>count</span>(<span>$data</span><span>)) {
                </span><span>$str</span>.=");\n\n-- --------------------------------------------------------\n\n"<span>;
            } </span><span>else</span><span> {
                </span><span>$str</span>.="),\n"<span>;
            }
        }
        </span><span>return</span> <span>$str</span><span>;
    }

     </span><span>//</span><span>备份数据库</span>
    <span>public</span> <span>function</span> getBackUpDataByTable (<span>$tables</span>, <span>$path</span>='', <span>$fileName</span> = 'seocheck', <span>$subsection</span> = '2'<span>) {
        </span><span>if</span>(<span>empty</span>(<span>$tables</span>)) <span>$this</span>->_showMsg('未能指定要备份的表!!!', <span>true</span><span>);
        </span><span>$page</span> = 0;<span>//</span><span>卷数</span>
        <span>$path</span> = <span>empty</span>(<span>$path</span>) ? <span>$_SERVER</span>['DOCUMENT_ROOT'].'/core/Runtime/Data/'.<span>$fileName</span>.'Demo/' : <span>$path</span><span>;
        </span><span>if</span>(!<span>file_exists</span>(<span>$path</span><span>)) {
            </span><span>mkdir</span>(<span>$path</span>, 0777, <span>true</span><span>);
        } www</span>.jbxue.<span>com
        </span><span>$mysql_info</span> = <span>$this</span>-><span>_retrieve();
        </span><span>$fieldsByTable</span> = <span>array</span><span>();
        </span><span>if</span>(<span>is_array</span>(<span>$tables</span><span>)) {
            </span><span>$this</span>->_showMsg('开始备份,数据正在初始化中,请勿关闭浏览器...'<span>);
            </span><span>$fw</span> = <span>$this</span>->writeFileByBackUpData(<span>$path</span>.<span>$this</span>->dbName.'_table.sql', <span>$mysql_info</span>, <span>$method</span>="ab+"<span>);
            </span><span>if</span>(<span>$fw</span> !== <span>false</span><span>) {
                </span><span>$this</span>->_showMsg('备份数据库基本信息成功。。。'<span>);
            }
            </span><span>foreach</span> (<span>$tables</span> <span>as</span> <span>$table</span><span>) {
                </span><span>$tableInfo</span> = <span>$this</span>->getFieldsByTable(<span>$table</span><span>);
                </span><span>if</span>(!<span>empty</span>(<span>$tableInfo</span><span>)) {
                    </span><span>$this</span>->_showMsg('获取表['.<span>$table</span>.']结构成功。。。'<span>);
                    </span><span>$fw</span> = <span>$this</span>->writeFileByBackUpData(<span>$path</span>.<span>$this</span>->dbName.'_table.sql', <span>$tableInfo</span>[<span>$table</span>], <span>$method</span>="ab+"<span>);
                    </span><span>if</span>(<span>$fw</span> === <span>false</span><span>) {
                        </span><span>$this</span>->_showMsg('备份表['.<span>$table</span>.']结构失败。。。', <span>true</span><span>);
                    } </span><span>else</span><span> {
                        </span><span>$this</span>->_showMsg('备份表['.<span>$table</span>.']结构成功,开始获取数据。。。'<span>);
                    };
                } </span><span>else</span><span> {
                    </span><span>$this</span>->_showMsg('获取数据库['.<span>$this</span>->dbName.']表结构失败,请稍后再试!。。。', <span>true</span><span>);
                }
                </span><span>$this</span>->_insertSqlByTableForAll(<span>$path</span>, <span>$table</span>, <span>$subsection</span><span>);
            }
        } </span><span>else</span><span> {
            </span><span>$this</span>->_showMsg('开始备份,数据正在初始化中,请勿关闭浏览器...'<span>);
            </span><span>$tableInfo</span> = <span>$this</span>->getFieldsByTable(<span>$tables</span><span>);
            </span><span>if</span>(!<span>empty</span>(<span>$tableInfo</span><span>)) {
                </span><span>$this</span>->_showMsg('获取表['.<span>$tables</span>.']结构成功。。。'<span>);
                </span><span>$fw</span> = <span>$this</span>->writeFileByBackUpData(<span>$path</span>.<span>$this</span>->dbName.'_'.<span>$tables</span>.'_table.sql', <span>$mysql_info</span>.<span>$tableInfo</span>[<span>$tables</span><span>]);
                </span><span>if</span>(<span>$fw</span> === <span>false</span><span>) {
                    </span><span>$this</span>->_showMsg('备份表['.<span>$tables</span>.']结构失败。。。', <span>true</span><span>);
                } </span><span>else</span><span> {
                    </span><span>$this</span>->_showMsg('备份表['.<span>$tables</span>.']结构成功,开始获取数据。。。'<span>);
                }
            } </span><span>else</span><span> {
                </span><span>$this</span>->_showMsg('获取表['.<span>$tables</span>.']结构失败,请稍后再试!。。。', <span>true</span><span>);
            }
            </span><span>$res</span> = <span>$this</span>->_insertSqlByTableForAll(<span>$path</span>, <span>$tables</span>, <span>$subsection</span><span>);
        }
    }

    </span><span>//</span><span>数据库基本信息</span>
    <span>private</span> <span>function</span><span> _retrieve() {
        </span><span>$backUp</span>  = ''<span>;
        </span><span>$backUp</span> .= '--' . "\n"<span>;
        </span><span>$backUp</span> .= '-- MySQL database dump' . "\n"<span>;
        </span><span>$backUp</span> .= '-- Created by DbBackUp class, Power By chujiu. ' . "\n"<span>;
        </span><span>$backUp</span> .= '--' . "\n"<span>;
        </span><span>$backUp</span> .= '-- 主机: ' . <span>$this</span>->host . "\n"<span>;
        </span><span>$backUp</span> .= '-- 生成日期: ' . <span>date</span> ( 'Y' ) . ' 年  ' . <span>date</span> ( 'm' ) . ' 月 ' . <span>date</span> ( 'd' ) . ' 日 ' . <span>date</span> ( 'H:i' ) . "\n"<span>;
        </span><span>$backUp</span> .= '-- MySQL版本: ' . <span>mysql_get_server_info</span> () . "\n"<span>;
        </span><span>$backUp</span> .= '-- PHP 版本: ' . <span>phpversion</span> () . "\n"<span>;
        </span><span>$backUp</span> .= "\n\n"<span>;
        </span><span>$backUp</span> .= "SET SQL_MODE='NO_AUTO_VALUE_ON_ZERO';\n"<span>;
        </span><span>$backUp</span> .= "SET time_zone = '+00:00';\n\n"<span>;
        </span><span>$backUp</span> .= "/*!40101 SET @OLD_CHARACTER_SET_CLIENT=@@CHARACTER_SET_CLIENT */;\n"<span>;
        </span><span>$backUp</span> .= "/*!40101 SET @OLD_CHARACTER_SET_RESULTS=@@CHARACTER_SET_RESULTS */;\n"<span>;
        </span><span>$backUp</span> .= "/*!40101 SET @OLD_COLLATION_CONNECTION=@@COLLATION_CONNECTION */;\n"<span>;
        </span><span>$backUp</span> .= "/*!40101 SET NAMES utf8*/;\n\n"<span>;
        </span><span>$backUp</span> .= "--\n-- Database: `{<span>$this</span>->dbName}`\n--\n\n-- --------------------------------------------------------\n\n"<span>;
        </span><span>return</span> <span>$backUp</span><span>;
    }

    </span><span>/*</span><span>*
     * 插入单条记录
     *
     * @param string $row
     </span><span>*/</span>
    <span>private</span> <span>function</span> _insertSql(<span>$row</span>, <span>$table</span><span>) {
        </span><span>//</span><span> sql字段逗号分割</span>
        <span>$insert</span> = ''<span>;
        </span><span>$insert</span> .= "INSERT INTO `" . <span>$table</span> . "` VALUES("<span>;
        </span><span>foreach</span>(<span>$row</span> <span>as</span> <span>$key</span>=><span>$val</span><span>) {
            </span><span>$insert</span> .= "'".<span>$val</span>."',"<span>;
        }
        </span><span>$insert</span> = <span>substr</span>(<span>$insert</span>, 0 ,-1<span>);
         </span><span>$insert</span> .= ");" . "\n"<span>;
        </span><span>return</span> <span>$insert</span><span>;
    }

    </span><span>/*</span><span>*
     * 生成一个表的inser语句
     * @param string $table
     * @param string $subsection 分卷大小
     </span><span>*/</span>
    <span>private</span> <span>function</span> _insertSqlByTableForAll(<span>$path</span>, <span>$table</span>, <span>$subsection</span><span>) {
        </span><span>$i</span> = 0<span>;
        </span><span>$insertSqlByTable</span> = ''<span>;
        </span><span>$res</span> = <span>mysql_query</span>("SELECT * FROM `{<span>$table</span>}`", <span>$this</span>-><span>conn);
        </span><span>if</span>(!<span>$res</span>) <span>die</span>('MySQL Error: ' . <span>mysql_error</span><span>());
        </span><span>while</span>(<span>$rows</span> = <span>mysql_fetch_assoc</span>(<span>$res</span><span>)) {
            </span><span>$insertSqlByTable</span> .= <span>$this</span>->_insertSql(<span>$rows</span>, <span>$table</span><span>);
            </span><span>$size</span> = <span>strlen</span>(<span>$insertSqlByTable</span><span>);
            </span><span>if</span>(<span>$size</span> > <span>$subsection</span>*1024*1024<span>) {
                </span><span>$fw</span> = <span>$this</span>->writeFileByBackUpData(<span>$path</span>.<span>$table</span>.<span>$i</span>.<span>$this</span>->tag.'.sql', <span>$insertSqlByTable</span><span>);
                </span><span>if</span>(<span>$fw</span> === <span>false</span>) <span>$this</span>->_showMsg('数据库表['.<span>$table</span>.'],卷 '.<span>$i</span>.' 写入文件失败,请稍后再试!!!',<span>true</span><span>);
                </span><span>$this</span>->_showMsg('数据库表['.<span>$table</span>.'],卷 '.<span>$i</span>.' 备份成功!备份文件:[ '.<span>$path</span>.<span>$table</span>.<span>$i</span>.<span>$this</span>->tag.'.sql ]'<span>);
                </span><span>$insertSqlByTable</span> = ''<span>;
                </span><span>$i</span>+=1<span>;
            }
        }
        </span><span>//</span><span> insertSqlByTable大小不够分卷大小</span>
        <span>if</span> (<span>$insertSqlByTable</span> != ""<span>) {
            </span><span>$fw</span> = <span>$this</span>->writeFileByBackUpData(<span>$path</span>.<span>$table</span>.<span>$this</span>->tag.'.sql', <span>$insertSqlByTable</span><span>);
            </span><span>if</span>(<span>$fw</span> === <span>false</span>) <span>$this</span>->_showMsg('数据库表['.<span>$table</span>.']写入文件失败,请稍后再试!!!备份文件:[ '.<span>$path</span>.<span>$table</span>.<span>$this</span>->tag.'.sql ]',<span>true</span><span>);
            </span><span>$this</span>->_showMsg('数据库表['.<span>$table</span>.'] 备份成功!备份文件:[ '.<span>$path</span>.<span>$table</span>.<span>$this</span>->tag.'.sql ]'<span>);
        }
        </span><span>$this</span>->_showMsg('数据库表['.<span>$table</span>.']全部备份成功!'<span>);
    }

    </span><span>//</span><span> 写入文件</span>
    <span>public</span> <span>function</span> writeFileByBackUpData(<span>$fileName</span>, <span>$data</span>, <span>$method</span>="rb+", <span>$iflock</span>=1, <span>$check</span>=1, <span>$chmod</span>=1<span>){
        </span><span>$check</span> && @<span>strpos</span>(<span>$fileName</span>, '..')!==<span>false</span> && <span>exit</span>('Forbidden'<span>);
        @</span><span>touch</span>(<span>$fileName</span><span>);
        </span><span>$handle</span> = @<span>fopen</span>(<span>$fileName</span>, <span>$method</span><span>);
        </span><span>if</span>(<span>$iflock</span><span>) {
            @</span><span>flock</span>(<span>$handle</span>,<span>LOCK_EX);
        }
        </span><span>$fw</span> = @<span>fwrite</span>(<span>$handle</span>,<span>$data</span><span>);
        </span><span>if</span>(<span>$method</span> == "rb+") <span>ftruncate</span>(<span>$handle</span>, <span>strlen</span>(<span>$data</span><span>));
        </span><span>fclose</span>(<span>$handle</span><span>);
        </span><span>$chmod</span> && @<span>chmod</span>(<span>$fileName</span>,0777<span>);
        </span><span>return</span> <span>$fw</span><span>;
    }

    </span><span>/*</span><span>*
     * path: 生成压缩包的路径
     * fileName : 要压缩的文件名 通常和path 同一目录
     </span><span>*/</span>
    <span>public</span> <span>function</span> createZipByBackUpFile(<span>$path</span><span>) {
        </span><span>$db_base_files</span> = <span>$this</span>->getFileByBackUpDir(<span>$path</span><span>);
        </span><span>if</span>(!<span>empty</span>(<span>$db_base_files</span><span>)) {
            </span><span>$zip</span> = <span>new</span><span> ZipArchive;
            </span><span>if</span>(<span>$zip</span>->open(<span>$path</span>.<span>$this</span>->dbName.<span>date</span>('Ymd').'.zip', ZipArchive::CREATE | ZIPARCHIVE::OVERWRITE) !== <span>true</span><span>) 
                </span><span>die</span> ("cannot open".<span>$this</span>->dbName.<span>date</span>('Ymd')."zip for writing."<span>);
            </span><span>foreach</span> (<span>$db_base_files</span> <span>as</span> <span>$key</span> => <span>$value</span><span>) {
                </span><span>if</span>(<span>is_file</span>(<span>$value</span><span>)) {
                    </span><span>$file_name</span> = <span>basename</span>(<span>$value</span><span>);
                    </span><span>$info</span>[] = <span>$zip</span>->addFile(<span>$value</span>, <span>$file_name</span>);<span>//</span><span> 避免压缩包里有文件的路径</span>
<span>                }
            }
            </span><span>$zip</span>-><span>close();
            </span><span>if</span>(<span>file_exists</span>(<span>$path</span>.<span>$this</span>->dbName.<span>date</span>('Ymd').'.zip'<span>))
            </span><span>foreach</span> (<span>$db_base_files</span> <span>as</span> <span>$val</span><span>) {
                </span><span>unlink</span>(<span>$val</span><span>);
            }
            </span><span>if</span>(<span>count</span>(<span>array_filter</span>(<span>$info</span>)) > 0) <span>return</span> <span>true</span><span>;
        }
        </span><span>return</span> <span>false</span><span>;
    }

    </span><span>//</span><span>获取文件</span>
    <span>public</span> <span>function</span> getFileByBackUpDir(<span>$path</span><span>) {
        </span><span>$info</span> = <span>array</span><span>();
        </span><span>$db_base_files</span> = <span>array</span><span>();
        </span><span>if</span>( @<span>file_exists</span>(<span>$path</span>) && <span>is_dir</span>(<span>$path</span><span>) ) {
            </span><span>if</span> (<span>$dh</span> = <span>opendir</span>(<span>$path</span><span>)) {
                </span><span>while</span> ((<span>$file</span> = <span>readdir</span>(<span>$dh</span>)) !== <span>false</span><span>) {
                    </span><span>if</span>(<span>$file</span> != '.' && <span>$file</span> != '..'<span>) {
                        </span><span>if</span>( <span>strripos</span>(<span>$file</span>, 'seocheck') !== <span>false</span><span> ) {
                            </span><span>$db_base_files</span>[] = <span>$path</span>.<span>$file</span><span>;
                        }
                    }
                }
                </span><span>closedir</span>(<span>$dh</span><span>);
            }
        }
        </span><span>return</span> <span>$db_base_files</span><span>;
    }

    </span><span>/*</span><span>*
     * @path: 生成压缩包的路径
     * @fileName : 要解压的文件名 默认解压到path 目录
     </span><span>*/</span>
    <span>public</span> <span>function</span> uncompressZip(<span>$path</span>, <span>$zipName</span><span>) {
        </span><span>$path</span> = <span>empty</span>(<span>$path</span>) ? <span>$_SERVER</span>['DOCUMENT_ROOT'].'/core/Runtime/Data/' : <span>$path</span><span>;
        </span><span>$zip</span> = <span>new</span><span> ZipArchive;
        </span><span>if</span> (<span>$zip</span>->open(<span>$path</span>.<span>$zipName</span>) === <span>TRUE</span><span>) {
            </span><span>$zip</span>->extractTo(<span>$path</span><span>);
            </span><span>$zip</span>-><span>close();
            </span><span>return</span> <span>true</span><span>;
        } </span><span>else</span><span> {
            </span><span>return</span> <span>false</span><span>;
        }
    }

    </span><span>//</span><span>导入数据库</span>
    <span>public</span> <span>function</span><span> importingDataBySqlFile () {

    }

    </span><span>//</span><span>  及时输出信息</span>
    <span>private</span> <span>function</span> _showMsg(<span>$msg</span>,<span>$err</span>=<span>false</span><span>){
        </span><span>if</span>(<span>$err</span> === <span>true</span><span>) {
            </span><span>echo</span> "<p style='font-size:14px;'><span style='color:red;'>ERROR: --- " . <span>$msg</span> . "</span></p>";<span>exit</span><span>;
        }
        </span><span>echo</span> "<p style='font-size:14px;'><span style='color:green;'>OK: --- " . <span>$msg</span> . "</span></p>"<span>;
    }

    </span><span>//</span><span> 锁定数据库,以免备份或导入时出错</span>
    <span>private</span> <span>function</span> lock(<span>$table</span>, <span>$op</span> = "WRITE"<span>) {
        </span><span>if</span> (<span>mysql_query</span> ( "lock tables " . <span>$table</span> . " " . <span>$op</span><span> ))
            </span><span>return</span> <span>true</span><span>;
        </span><span>else</span>
            <span>return</span> <span>false</span><span>;
    }

    </span><span>//</span><span> 解锁</span>
    <span>private</span> <span>function</span><span> unlock() {
        </span><span>if</span> (<span>mysql_query</span> ( "unlock tables"<span> ))
            </span><span>return</span> <span>true</span><span>;
        </span><span>else</span>
            <span>return</span> <span>false</span><span>;
    }

    </span><span>//</span><span> 析构</span>
    <span>public</span> <span>function</span><span> __destruct() {
        </span><span>if</span>(<span>$this</span>-><span>conn){
            </span><span>mysql_query</span> ( "unlock tables", <span>$this</span>-><span>conn );
            </span><span>mysql_close</span> ( <span>$this</span>-><span>conn );
        }
    }
}
</span>?>

www.bkjia.comtruehttp://www.bkjia.com/PHPjc/771956.htmlTechArticle本代码实现了表结构和数据完全分开,默认有一个文件会记录所有表的结构,然后表中数据的备份 如果超过分卷的大小则会分成多个文件,...
성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
PHP : 서버 측 스크립팅 언어 소개PHP : 서버 측 스크립팅 언어 소개Apr 16, 2025 am 12:18 AM

PHP는 동적 웹 개발 및 서버 측 응용 프로그램에 사용되는 서버 측 스크립팅 언어입니다. 1.PHP는 편집이 필요하지 않으며 빠른 발전에 적합한 해석 된 언어입니다. 2. PHP 코드는 HTML에 포함되어 웹 페이지를 쉽게 개발할 수 있습니다. 3. PHP는 서버 측 로직을 처리하고 HTML 출력을 생성하며 사용자 상호 작용 및 데이터 처리를 지원합니다. 4. PHP는 데이터베이스와 상호 작용하고 프로세스 양식 제출 및 서버 측 작업을 실행할 수 있습니다.

PHP 및 웹 : 장기적인 영향 탐색PHP 및 웹 : 장기적인 영향 탐색Apr 16, 2025 am 12:17 AM

PHP는 지난 수십 년 동안 네트워크를 형성했으며 웹 개발에서 계속 중요한 역할을 할 것입니다. 1) PHP는 1994 년에 시작되었으며 MySQL과의 원활한 통합으로 인해 개발자에게 최초의 선택이되었습니다. 2) 핵심 기능에는 동적 컨텐츠 생성 및 데이터베이스와의 통합이 포함되며 웹 사이트를 실시간으로 업데이트하고 맞춤형 방식으로 표시 할 수 있습니다. 3) PHP의 광범위한 응용 및 생태계는 장기적인 영향을 미쳤지 만 버전 업데이트 및 보안 문제에 직면 해 있습니다. 4) PHP7의 출시와 같은 최근 몇 년간의 성능 향상을 통해 현대 언어와 경쟁 할 수 있습니다. 5) 앞으로 PHP는 컨테이너화 및 마이크로 서비스와 같은 새로운 도전을 다루어야하지만 유연성과 활발한 커뮤니티로 인해 적응력이 있습니다.

PHP를 사용하는 이유는 무엇입니까? 설명 된 장점과 혜택PHP를 사용하는 이유는 무엇입니까? 설명 된 장점과 혜택Apr 16, 2025 am 12:16 AM

PHP의 핵심 이점에는 학습 용이성, 강력한 웹 개발 지원, 풍부한 라이브러리 및 프레임 워크, 고성능 및 확장 성, 크로스 플랫폼 호환성 및 비용 효율성이 포함됩니다. 1) 배우고 사용하기 쉽고 초보자에게 적합합니다. 2) 웹 서버와 우수한 통합 및 여러 데이터베이스를 지원합니다. 3) Laravel과 같은 강력한 프레임 워크가 있습니다. 4) 최적화를 통해 고성능을 달성 할 수 있습니다. 5) 여러 운영 체제 지원; 6) 개발 비용을 줄이기위한 오픈 소스.

신화를 폭로 : PHP가 실제로 죽은 언어입니까?신화를 폭로 : PHP가 실제로 죽은 언어입니까?Apr 16, 2025 am 12:15 AM

PHP는 죽지 않았습니다. 1) PHP 커뮤니티는 성능 및 보안 문제를 적극적으로 해결하고 PHP7.x는 성능을 향상시킵니다. 2) PHP는 최신 웹 개발에 적합하며 대규모 웹 사이트에서 널리 사용됩니다. 3) PHP는 배우기 쉽고 서버가 잘 수행되지만 유형 시스템은 정적 언어만큼 엄격하지 않습니다. 4) PHP는 컨텐츠 관리 및 전자 상거래 분야에서 여전히 중요하며 생태계는 계속 발전하고 있습니다. 5) Opcache 및 APC를 통해 성능을 최적화하고 OOP 및 설계 패턴을 사용하여 코드 품질을 향상시킵니다.

PHP vs. Python 토론 : 어느 것이 더 낫습니까?PHP vs. Python 토론 : 어느 것이 더 낫습니까?Apr 16, 2025 am 12:03 AM

PHP와 Python에는 고유 한 장점과 단점이 있으며 선택은 프로젝트 요구 사항에 따라 다릅니다. 1) PHP는 웹 개발, 배우기 쉽고 풍부한 커뮤니티 리소스에 적합하지만 구문은 현대적이지 않으며 성능과 보안에주의를 기울여야합니다. 2) Python은 간결한 구문과 배우기 쉬운 데이터 과학 및 기계 학습에 적합하지만 실행 속도 및 메모리 관리에는 병목 현상이 있습니다.

PHP의 목적 : 동적 웹 사이트 구축PHP의 목적 : 동적 웹 사이트 구축Apr 15, 2025 am 12:18 AM

PHP는 동적 웹 사이트를 구축하는 데 사용되며 해당 핵심 기능에는 다음이 포함됩니다. 1. 데이터베이스와 연결하여 동적 컨텐츠를 생성하고 웹 페이지를 실시간으로 생성합니다. 2. 사용자 상호 작용 및 양식 제출을 처리하고 입력을 확인하고 작업에 응답합니다. 3. 개인화 된 경험을 제공하기 위해 세션 및 사용자 인증을 관리합니다. 4. 성능을 최적화하고 모범 사례를 따라 웹 사이트 효율성 및 보안을 개선하십시오.

PHP : 데이터베이스 및 서버 측 로직 처리PHP : 데이터베이스 및 서버 측 로직 처리Apr 15, 2025 am 12:15 AM

PHP는 MySQLI 및 PDO 확장 기능을 사용하여 데이터베이스 작업 및 서버 측 로직 프로세싱에서 상호 작용하고 세션 관리와 같은 기능을 통해 서버 측로 로직을 처리합니다. 1) MySQLI 또는 PDO를 사용하여 데이터베이스에 연결하고 SQL 쿼리를 실행하십시오. 2) 세션 관리 및 기타 기능을 통해 HTTP 요청 및 사용자 상태를 처리합니다. 3) 트랜잭션을 사용하여 데이터베이스 작업의 원자력을 보장하십시오. 4) SQL 주입 방지, 디버깅을 위해 예외 처리 및 폐쇄 연결을 사용하십시오. 5) 인덱싱 및 캐시를 통해 성능을 최적화하고, 읽을 수있는 코드를 작성하고, 오류 처리를 수행하십시오.

PHP에서 SQL 주입을 어떻게 방지합니까? (준비된 진술, pdo)PHP에서 SQL 주입을 어떻게 방지합니까? (준비된 진술, pdo)Apr 15, 2025 am 12:15 AM

PHP에서 전처리 문과 PDO를 사용하면 SQL 주입 공격을 효과적으로 방지 할 수 있습니다. 1) PDO를 사용하여 데이터베이스에 연결하고 오류 모드를 설정하십시오. 2) 준비 방법을 통해 전처리 명세서를 작성하고 자리 표시자를 사용하여 데이터를 전달하고 방법을 실행하십시오. 3) 쿼리 결과를 처리하고 코드의 보안 및 성능을 보장합니다.

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
4 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
4 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
4 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 채팅 명령 및 사용 방법
4 몇 주 전By尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

VSCode Windows 64비트 다운로드

VSCode Windows 64비트 다운로드

Microsoft에서 출시한 강력한 무료 IDE 편집기

DVWA

DVWA

DVWA(Damn Vulnerable Web App)는 매우 취약한 PHP/MySQL 웹 애플리케이션입니다. 주요 목표는 보안 전문가가 법적 환경에서 자신의 기술과 도구를 테스트하고, 웹 개발자가 웹 응용 프로그램 보안 프로세스를 더 잘 이해할 수 있도록 돕고, 교사/학생이 교실 환경 웹 응용 프로그램에서 가르치고 배울 수 있도록 돕는 것입니다. 보안. DVWA의 목표는 다양한 난이도의 간단하고 간단한 인터페이스를 통해 가장 일반적인 웹 취약점 중 일부를 연습하는 것입니다. 이 소프트웨어는

SublimeText3 Linux 새 버전

SublimeText3 Linux 새 버전

SublimeText3 Linux 최신 버전

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

맨티스BT

맨티스BT

Mantis는 제품 결함 추적을 돕기 위해 설계된 배포하기 쉬운 웹 기반 결함 추적 도구입니다. PHP, MySQL 및 웹 서버가 필요합니다. 데모 및 호스팅 서비스를 확인해 보세요.