tp框架简易导出数据库
类库,将以下文件放入vendor文件夹中,命名空间vendor,使用think下的model类
<?php
/**
* 描述:基于ThinkPHP框架的Mysql数据库导出类
* 日期:2012-07-15
* 作者:龚辟愚
*/
namespace Vendor;
use Think\Model;
class DBExport
{
/**
* @description 获取当前数据库的所有表名。
* @static
* @return array
*/
public function t(){
echo "a";
}
static protected function gettables()
{
$dbName=C('DB_NAME'); $result=M()->query("SHOW FULL tableS FROM `{$dbName}` WHERE table_Type = 'BASE table'"); foreach ($result as $v){
$tbArray[]=$v['tables_in_'.C('DB_NAME')];
}
return $tbArray; }
static protected function getViews()
{
$dbName=C('DB_NAME');
$result=M()->query("SHOW FULL tableS FROM `{$dbName}` WHERE table_Type = 'VIEW'"); foreach ($result as $v){
$tbArray[]=$v['tables_in_'.C('DB_NAME')];
}
return $tbArray;
} /**
* @description 导出SQL数据,但不包含表创建代码。
* @static
* @return string
*/
static public function ExportAllData()
{
$tables = self::gettables();
$arrAll = array(
"SET FOREIGN_KEY_CHECKS=0;",
self::BuildAllTriggerDropSql(),
self::BuildtableSql(),
self::BuildViewSql()
);
$tbl = new Model();
foreach($tables as $table)
{
$arrAll[]="\r\nDELETE FROM {$table};"; /*
$rs = $tbl->query("SHOW COLUMNS FROM {$table}");
$arrFields = array();
foreach ($rs as $k=>&$v){
$arrFields[] = "`{$v['Field']}`"; } $sqlFields = implode($arrFields,",");
*/
$rs=$tbl->query("select * from `{$table}`");
foreach ($rs as $k=>&$v){
$arrValues = array();
foreach($v as $key=>$val)
{
if(is_numeric($val)){
$arrValues[]=$val;
}else if(is_null($val)){
$arrValues[]='NULL';
}else{
$arrValues[]="'".addslashes($val)."'";
}
}
$arrAll[] = "INSERT INTO `{$table}` VALUES (".implode(',',$arrValues).");";
}
}
$arrAll[]=self::BuildTriggerCreateSql();
return implode("\r\n",$arrAll);
} static protected function BuildtableSql()
{
$tables = self::gettables();
$arrAll = array();
foreach($tables as &$val){
$rs = M()->query("SHOW CREATE table `{$val}`"); $tbSql = preg_replace("#CREATE(.*)\\s+table#","CREATE table",$rs[0]['Create table']); $arrAll[] = "DROP table IF EXISTS `{$rs[0]['table']}`;\r\n{$tbSql};\r\n";
} return implode("\r\n",$arrAll);
} static protected function BuildViewSql()
{
$views = self::getViews();
$arrAll = array();
foreach($views as &$val){
$rs = M()->query("SHOW CREATE VIEW `{$val}`");
$tbSql = preg_replace("#CREATE(.*)\\s+VIEW#","CREATE VIEW",$rs[0]['Create View']); $arrAll[] = "DROP VIEW IF EXISTS `{$rs[0]['View']}`;\r\n{$tbSql};\r\n";
}
return implode("\r\n",$arrAll);
}
/**
* @description 如果存在触发器,生成删除代码。原因是:插入数据的时候可能会受到触发器影响。
* @static
* @return string
*/
static public function BuildAllTriggerDropSql()
{
$rs = M()->query("show triggers");
$arrAll = array();
foreach ($rs as $k=>&$v)
{
$arrSql = array(
'DROP TRIGGER IF EXISTS `',$v['Trigger'],'`;'
); $arrAll[] = implode('',$arrSql);
}
return implode("\r\n",$arrAll);
} /**
* @description 生成所有触发器的创建代码。
* @static
* @return string
*/
static protected function BuildTriggerCreateSql()
{
$rs = M()->query("show triggers");
$arrAll = array();
foreach ($rs as $k=>&$v)
{
$arrSql = array(
'CREATE TRIGGER `',$v['Trigger'],'` ',$v['Timing'],' ',$v['Event'],' ON `',
$v['table'],'` FOR EACH ROW ',$v['Statement'],';'
); $arrAll[] = implode('',$arrSql);
}
return implode("\r\n",$arrAll);
}
}
//调用方法
public function tiaoshi(){
header('Content-type: text/plain; charset=UTF-8');
$dbName = C('DB_NAME');
header("Content-Disposition: attachment; filename=\"{$dbName}.sql\"");
vendor('DBExport','','.class.php');
echo \vendor\DBExport::ExportAllData();
}
tp框架简易导出数据库的更多相关文章
- 用tp框架来对数据库进行增删改
先来看添加 使用tp框架,对数据库进行添加操作,都有哪些方法 先在Main控制器中,做个方法 运行一下,注意地址,就要输tianjia了 然后再看一下数据库,有没有添加上数据 添加成功 再来看一下这个 ...
- tp框架下,数据库和编辑器都是utf-8, 输出中文却还是乱码
输出: array(2) { [0]=> array(4) { ["id"]=> string(1) "1" ["user"]= ...
- tp框架 :操作数据库
操作数据库,进行增删改数据 一.对数据表添加数据(方法:add()) (1)上一篇已经讲过链接数据库了,继续进行对数据库的操作,还是用控制器文件中的HomeController.class文件 看下数 ...
- tp框架中 关于数据库mysql 的一些疑点知识
mysql创建索引, 通常是在 创建表的 同时/时候, 就创建了 即使是在win下, 用命令行操作数据库 , 也要比 图形界面的鼠标操作快得多 索引的类型有: unique, fulltext索引, ...
- tp框架设置 mysql数据库的端口号
<?php return array( //'配置项'=>'配置值' SHOW_PAGE_TRACE=>true,//开启trace信息 'DB_TYPE' => 'mysql ...
- ThinkPhp框架:有条件的数据库查询、tp框架的其他知识
上一篇的随笔写的是基本操作,现在可以做一些高级操作,例如有条件的查询数据,有分页的条件查询数据 一.一个条件的查询数据 查询数据自然是先要显示出数据,然后根据条件进行查询数据 (1)显示出表的数据 这 ...
- .net mvc 站点自带简易SSL加密传输 Word报告自动生成(例如 导出数据库结构) 微信小程序:动画(Animation) SignalR 设计理念(一) ASP.NET -- WebForm -- ViewState ASP.NET -- 一般处理程序ashx 常用到的一些js方法,记录一下 CryptoJS与C#AES加解密互转
.net mvc 站点自带简易SSL加密传输 因项目需要,传输数据需要加密,因此有了一些经验,现简易抽出来分享! 请求:前端cryptojs用rsa/aes 或 rsa/des加密,后端.net ...
- tp框架where条件查询数据库
tp框架where条件查询数据库 Where 条件表达式格式为: $map['字段名'] = array('表达式', '操作条件'); 其中 $map 是一个普通的数组变量,可以根据自己需求而命名. ...
- 混合框架中Oracle数据库的还原处理操作
在较早期的随笔<Oracle如何实现创建数据库.备份数据库及数据导出导入的一条龙操作>粗略介绍了Oracle数据库的备份还原操作,本文想从开发框架的基础上介绍Oracle数据库的脚本或者还 ...
随机推荐
- C语言中extern的用法
0x01 extern用在变量或函数的声明前,用来说明“此变量/函数是在别处定义的,要在此处引用”. 0x02 extern修饰变量的声明. 举例:若a.c中需引用b.c中的变量int v,可以在a. ...
- 安装sass并ruby更改淘宝镜像
一.安装ruby 去官网下载ruby安装(注意:安装的时候选择第二项变量环境安装add ruby executables to your PATH) 二.安装完成后 在windows左下角打开所有应用 ...
- Maximo子表中增加附件功能
附件功能的实现(详见ewell.webclient.beans.warranty.WarrantysDateBean ,ewell.webclient.beans.doclinks.custom.Ad ...
- Objective - C NSArray不可变数组和NSMutableArray可变数组
OC中存储数据最常用 的两个容器就是数组和字典,而作为最常用的,应该了解这所有的特点,及用法. OC中的数组是一个容量,有序的管理了一系列元素,并且存放在数组里的元素,必须是对象类型. 不可变数组,见 ...
- php面试题目
PHP测试小例 1. 禁用COOKIE 后 SEESION 还能用吗? Cookie 是保存在浏览器 1.cookie是保存在本地的,而seesion是保存在服务器上的.所以两者没有直接的关系,禁用 ...
- java的继承和重写
继承是面向对象最显著的一个特性.继承是从已有的类中派生出新的类,新的类能吸收已有类的数据属性和行为,并能扩展新的能力.[1] Java继承是使用已存在的类的定义作为基础建立新类的技术,新类的定义可以 ...
- 浅述python中argsort()函数的用法
由于想使用python用训练好的caffemodel来对很多图片进行批处理分类,学习过程中,碰到了argsort函数,因此去查了相关文献,也自己在python环境下进行了测试,大概了解了其相关的用处, ...
- SQLServer : EXEC和sp_executesql的区别
MSSQL为我们提供了两种动态执行SQL语句的命令,分别是EXEC和sp_executesql.通常,sp_executesql则更具有优势,它提供了输入输出接口,而EXEC没有.还有一个最大的好处就 ...
- C# iis 错误配置信息( 500.19 - Internal Server Error )
出现这个错误是因为 IIS 7 采用了更安全的 web.config 管理机制,默认情况下会锁住配置项不允许更改. 要取消锁定可以以管理员身份运行命令行 %windir%\system3 ...
- 打造一个有感觉的vim(四)
今天要介绍的VIM插件的名字叫做surround,这个插件的主要作用是将一个VIM的tex-objects(文本对象)添加或者取消包裹(单引号,双引号,XML标签等等)下载地址如下:https://g ...