php备份数据库,php备份
<span><?<span>php </span><span>/*</span><span>* * * @name php备份数据库 * @param string $DbHost 连接主机 * @param string $DbUser 用户名 * @param string $DbPwd 连接密码 * @param string $DbName 要备份的数据库 * @param string $saveFileName 要保存的文件名, 默认文件保存在当前文件夹中,以日期作区分 * @return Null * @example backupMySqlData('localhost', 'root', '123456', 'YourDbName'); * </span><span>*/</span> <span>function</span> backupMySqlData(<span>$DbHost</span>, <span>$DbUser</span>, <span>$DbPwd</span>, <span>$DbName</span>, <span>$saveFileName</span> = ''<span>) { </span><span>header</span>("Content-type:text/html;charset=utf-8"<span>); </span><span>error_reporting</span>(0<span>); </span><span>set_time_limit</span>(0<span>); </span><span>echo</span> '数据备份中,请稍候......<br />'<span>; </span><span>$link</span> = <span>mysql_connect</span>(<span>$DbHost</span>, <span>$DbUser</span>, <span>$DbPwd</span>) or <span>die</span>('数据库连接失败: ' . <span>mysql_error</span><span>()); </span><span>mysql_select_db</span>(<span>$DbName</span>) or <span>die</span>('数据库连接失败: ' . <span>mysql_error</span><span>()); </span><span>mysql_query</span>('set names utf8'<span>); </span><span>//</span><span> 声明变量</span> <span>$isDropInfo</span> = ''<span>; </span><span>$insertSQL</span> = ''<span>; </span><span>$row</span> = <span>array</span><span>(); </span><span>$tables</span> = <span>array</span><span>(); </span><span>$tableStructure</span> = <span>array</span><span>(); </span><span>$fileName</span> = (<span>$saveFileName</span> ? <span>$saveFileName</span> : 'MySQL_data_bakeup_') . <span>date</span>('YmdHis') . '.sql'<span>; </span><span>//</span><span> 枚举该数据库所有的表</span> <span>$res</span> = <span>mysql_query</span>("SHOW TABLES FROM <span>$DbName</span>"<span>); </span><span>while</span> (<span>$row</span> = <span>mysql_fetch_row</span>(<span>$res</span><span>)) { </span><span>$tables</span>[] = <span>$row</span>[0<span>]; } </span><span>mysql_free_result</span>(<span>$res</span><span>); </span><span>//</span><span> 枚举所有表的创建语句</span> <span>foreach</span> (<span>$tables</span> <span>as</span> <span>$val</span><span>) { </span><span>$res</span> = <span>mysql_query</span>("show create table <span>$val</span>", <span>$link</span><span>); </span><span>$row</span> = <span>mysql_fetch_row</span>(<span>$res</span><span>); </span><span>$isDropInfo</span> = "DROP TABLE IF EXISTS `" . <span>$val</span> . "`;\r\n"<span>; </span><span>$tableStructure</span> = <span>$isDropInfo</span> . <span>$row</span>[1] . ";\r\n"<span>; </span><span>file_put_contents</span>(<span>$fileName</span>, <span>$tableStructure</span>,<span> FILE_APPEND); </span><span>mysql_free_result</span>(<span>$res</span><span>); } </span><span>//</span><span> 枚举所有表的INSERT语句</span> <span>foreach</span> (<span>$tables</span> <span>as</span> <span>$val</span><span>) { </span><span>$res</span> = <span>mysql_query</span>("select * from <span>$val</span>"<span>); </span><span>//</span><span> 没有数据的表不执行insert</span> <span>while</span> (<span>$row</span> = <span>mysql_fetch_row</span>(<span>$res</span><span>)) { </span><span>$sqlStr</span> = "INSERT INTO `".<span>$val</span>."` VALUES ("<span>; </span><span>foreach</span>(<span>$row</span> <span>as</span> <span>$v</span><span>){ </span><span>$sqlStr</span> .= "'<span>$v</span>',"<span>; } </span><span>//</span><span>去掉最后一个逗号</span> <span>$sqlStr</span> = <span>substr</span>(<span>$sqlStr</span>, 0, <span>strlen</span>(<span>$sqlStr</span>) - 1<span>); </span><span>$sqlStr</span> .= ");\r\n"<span>; </span><span>file_put_contents</span>(<span>$fileName</span>, <span>$sqlStr</span>,<span> FILE_APPEND); } </span><span>mysql_free_result</span>(<span>$res</span><span>); } </span><span>echo</span> '数据备份成功!'<span>; } // 调用此方法 backupMySqlData(</span>'localhost', 'root', '123456', 'YouDbName'<span>); </span>?></span>
声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章
R.E.P.O.能量晶体解释及其做什么(黄色晶体)
1 个月前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳图形设置
1 个月前By尊渡假赌尊渡假赌尊渡假赌
刺客信条阴影:贝壳谜语解决方案
2 周前ByDDD
R.E.P.O.如果您听不到任何人,如何修复音频
1 个月前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.聊天命令以及如何使用它们
1 个月前By尊渡假赌尊渡假赌尊渡假赌

热工具

适用于 Eclipse 的 SAP NetWeaver 服务器适配器
将Eclipse与SAP NetWeaver应用服务器集成。

安全考试浏览器
Safe Exam Browser是一个安全的浏览器环境,用于安全地进行在线考试。该软件将任何计算机变成一个安全的工作站。它控制对任何实用工具的访问,并防止学生使用未经授权的资源。

Atom编辑器mac版下载
最流行的的开源编辑器

Dreamweaver CS6
视觉化网页开发工具

Dreamweaver Mac版
视觉化网页开发工具