一段导出数据库的代码

原创 2004年07月05日 00:05:00
一段导出数据库的代码
2004-06-16          点击: 11
一段导出数据库的代码
<?
//
$dbname="mytest";
$filename="file.sql";
mysql_pconnect ("localhost:3306","root","");
//
function sqldumptable($table) {
global $DB_site;
$tabledump = "DROP TABLE IF EXISTS $table;/n";
$tabledump .= "CREATE TABLE $table (/n";
$firstfield=1;
$fields = mysql_query("SHOW FIELDS FROM $table");
while ($field = mysql_fetch_array($fields)) {
if (!$firstfield) {$tabledump .= ",/n";} else {$firstfield=0;}
$tabledump .= " $field[Field] $field[Type]";
if (!empty($field["Default"])) {$tabledump .= " DEFAULT '$field[Default]'";}
if ($field[Null] != "YES") {$tabledump .= " NOT NULL";}
if ($field[Extra] != "") {$tabledump .= " $field[Extra]";}
}
mysql_free_result($fields);
$keys = mysql_query("SHOW KEYS FROM $table");
while ($key = mysql_fetch_array($keys)) {
$kname=$key['Key_name'];
if ($kname != "PRIMARY" and $key['Non_unique'] == 0) { $kname="UNIQUE|$kname";}
if(!is_array($index[$kname])) { $index[$kname] = array();}
$index[$kname][] = $key['Column_name'];
}
mysql_free_result($keys);

// get each key info
while(list($kname, $columns) = @each($index)){
$tabledump .= ",/n";
$colnames=implode($columns,",");

if($kname == "PRIMARY"){ $tabledump .= " PRIMARY KEY ($colnames)";}
else {
if (substr($kname,0,6) == "UNIQUE") {
// key is unique
$kname=substr($kname,7);
}

$tabledump .= " KEY $kname ($colnames)";

}
}

$tabledump .= "/n);/n/n";

// get data
$rows = mysql_query("SELECT * FROM $table");
$numfields=mysql_num_fields($rows);
while ($row = mysql_fetch_array($rows)) {
$tabledump .= "INSERT INTO $table VALUES(";

$fieldcounter=-1;
$firstfield=1;
// get each field's data
while (++$fieldcounter<$numfields) {
if (!$firstfield) {
$tabledump.=",";
} else {
$firstfield=0;
}

if (!isset($row[$fieldcounter])) {
$tabledump .= "NULL";
} else {
$tabledump .= "'".addslashes($row[$fieldcounter])."'";
}
}

$tabledump .= ");/n";
}
mysql_free_result($rows);

return $tabledump;
}
//函数结束
//
$result = mysql_list_tables ($dbname);
$i = 0;
while ($i < mysql_num_rows ($result)) {
$tb_names[$i] = mysql_tablename ($result, $i);
$dump.=sqldumptable($tb_names[$i])."/n/n/n";
$i++;
}

echo $dump;//可以在浏览器里输出看看
$filehandle=fopen($filename,"w");
fwrite($filehandle,$dump."/n/n/n");
fclose($filehandle);

echo "<p>数据成功导出!</p>";
?>
把$filename="file.sql";改成$filename="file.txt";
版权声明:本文为博主原创文章,未经博主允许不得转载。

Magento后台,自定义导出一段时间内销售最好的商品

1.页面 \app\design\adminhtml\default\default\template\report\grid\container.phtml getUrl(...
  • github_26672553
  • github_26672553
  • 2016年03月04日 13:27
  • 402

一段神奇的代码

做一个优雅的程序员,好像是很多程序员的一大目标,何为优雅,如何优雅?下面是一段神奇的代码,什么编码风格,什么编程规范,统统丢到一边吧,化腐朽为神奇才是更加难能可贵的! #define M 0...
  • u011836061
  • u011836061
  • 2015年06月04日 12:55
  • 1110

android 代码将数据库文件导出到sd卡

public static void save() { String dbpath = "/data/data/tl.cac.view/databases/" +"afinal.db"; boolea...
  • wuhongqi0012
  • wuhongqi0012
  • 2013年12月09日 13:50
  • 1427

C语言宏定义的学习------一个宏代表一段代码

开拓视野,以方便对代码的学习、研读和编写。 1\ #ifdef __MMI_BOOTUP_SCALE__ #define MMI_APP_INIT(func) {U32 start_time...
  • yuyantai1234
  • yuyantai1234
  • 2012年05月27日 13:30
  • 4111

ALLLEGRO中导入DXF文件步骤

ALLLEGRO中导入DXF文件步骤:1.File-->import-->DXF... 进入DXF In对话框 2.选定好路径,设置好单位(在CAD做的DXF文件中单位一般为MM,所以换一下,否则有时...
  • reille
  • reille
  • 2008年06月27日 16:27
  • 1529

数据库批量导出数据,可以拿去直接使用,程序员来涨姿势啦(二)

两毛五哥哥 12-11 01:52 看导入功能的话链接这在: 批量导入数据到数据库,使用最新的技术,来涨姿势啦(一) 今天写导出功能: 前端:Angularjs + bootstra...
  • u011277123
  • u011277123
  • 2017年01月05日 10:32
  • 1180

一段神奇的代码!

只要你在IE浏览器任意打开一个网站,然后在浏览器上输入如下代码神奇的代码,可随意修改复制页面内容! 神奇的代码 1神奇的代码1 javascript:R=0; x1=.1; y1=.05;...
  • zqtsx
  • zqtsx
  • 2013年03月24日 14:16
  • 1351

一段代码学习几个Python知识点

########################################################### zip(a, b)函数,将它可迭代的对象a, b作为参数,将a, b中对应的元...
  • vernice
  • vernice
  • 2016年03月19日 11:09
  • 1503

一段有趣的代码

把以下代码复制到IE地址栏里按回车,嘿嘿javascript:R=0; x1=.1; y1=.05; x2=.25; y2=.24; x3=1.6; y3=.24; x4=300; y4=200; x...
  • xbin8
  • xbin8
  • 2008年03月08日 21:48
  • 601

一段绕过JDBC的数据库交互代码

交互的数据库是H2  package org.roy.db; import java.util.Properties; import org.h2.command.CommandInterfac...
  • tsxuehu
  • tsxuehu
  • 2013年11月16日 15:19
  • 344
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:一段导出数据库的代码
举报原因:
原因补充:

(最多只允许输入30个字)