PHPでデータベーステーブルをjson/word/xml/excel_PHPにエクスポートする方法チュートリアル
- WBOYオリジナル
- 2016-07-14 10:08:18930ブラウズ
データベース情報エクスポート:word、excel、json、xml、sql
データベースのリカバリ: SQL から、ファイルから
具体的な使用方法:
まず新しいテストデータベース mytest を作成し、次にその中にテーブルを作成します
PHPコード:
以下はコードスニペットです:
--
-- テーブル構造「テスト」
--
CREATE TABLE `test` (
`id` int(11) NOT NULL auto_increment、
`name` varchar(100) NOT NULL、
`email` varchar(200) NOT NULL、
`age` int(3) NOT NULL、
主キー (`id`)
) ENGINE=MyISAM デフォルト CHARSET=utf8 AUTO_INCREMENT=3;
--
-- テーブル `test` 内のデータをエクスポートします
--
`test` (`id`、`name`、`email`、`age`) の値を挿入します
(1, 'pjq518', [email=]'pjq518@126.com'[/email], 22),
(2, 'xiaoyu', [email=]'xiaoyu@126.com'[/email], 21);
1. extで簡単に呼び出せるJSONをエクスポートします
PHPコード:
以下はコードスニペットです:
$db=新しいデータベース();
echo $db->toExtJson('test');
//出力結果は
です
//{'totalCount':'2','rows':[{'id':'1','name':'pjq518','email':'pjq518@126.com','age': '22'},{'id':'2','name':'xiaoyu','email':'xiaoyu@126.com','age':'21'}]}
toExtJson($table, $start="0", $limit="10", $cons="") には 4 つのパラメーターがあり、$table はテーブル名、$cons は文字列または配列の条件です
2. XMLをエクスポートする
PHPコード:
以下はコードスニペットです:
$db=新しいデータベース();
echo $db->toExtXml('test');
//結果を出力する
3. ExcelとWordをエクスポートします
PHPコード:
以下はコードスニペットです:
$db=新しいdb();
//エクセルへ
$map=array('No','Name','Email','Age');//ヘッダー
$db->toExcel('test', $map,'file');
//単語テーブルをエクスポートする
// $db->toWord('test', $map,'file');
//効果は以下の通りです
PHPコード:
クラス DB {
var $conn;
/*************************************************** * ***************************
* データベースに接続します
* return: MySQL 接続 ID、失敗した場合は FALSE を返します
************************************************ ***** *************************/
function Db($host="localhost",$user="root",$pass="123456",$db="juren_kamao") {
if(!$this->conn=mysql_connect($host,$user,$pass))
die("mysql サーバーに接続できません");
mysql_select_db($db,$this->conn);
mysql_query("SET NAMES 'UTF-8'");
}
/*************************************************** * ***************************
* SQLクエリを実行します
* return: クエリ構造セットリソース
************************************************ **************************/
関数実行($sql) {
mysql_query($sql,$this->conn);を返す
}
/*********************************************** ***************************
* 構造体セット内の行数を返します
* 戻り値:番号番号
************************************************ *************************/
function findCount($sql) {
$result=$this->execute($sql);
return mysql_num_rows($result);
}
/*************************************************** * ***************************
* SQLクエリを実行します
* 戻り値: 配列 配列
************************************************ ***** *************************/
関数 findBySql($sql) {
$array=array();
$result=mysql_query($sql);
$i=0;
while($row=mysql_fetch_assoc($result)) {
$array[$i]=$row;
$i++;
}
$array;
を返す
}
/*************************************************** * ***************************
*$conのいくつかの状況
*空: すべてのレコードを返します
*array: 例: array('id'=>'1') は id=1 のレコードを返します
*string :eg. 'id=1' id=1 のレコードを返します
* return: json形式のデータ
************************************************ **************************/
function toExtJson($table,$start="0",$limit="10",$cons="") {
$sql=$this->generateSql($table,$cons);
$totalNum=$this->findCount($sql);
$result=$this->findBySql($sql." LIMIT ".$start." ,".$limit);
$resultNum = count($result);//当前结果数
$str="";
$str.= "{";
$str.= "'totalCount':'right$totalNum',";
$str.="'rows':";
$str.="[";
for($i=0;$i
$str.="{";
$count=count($result[$i]);
$j=1;
foreach($result[$i] as $key=>$val) {
if($j
$str.="'".$key."':'".$val."',";
}
elseif($j==$count) {
$str.="'".$key."':'".$val."'";
}
$j++;
}
$str.="}";
if ($i != $resultNum-1) {
$str.= ", ";
}
}
$str.="]";
$str.="}";
return $str;
}
/*************************************************** * ***************************
* $table: テーブル名
* $cons:sql 条件
* return:SQL ステートメント
************************************************ **************************/
functiongenerateSql($table,$cons) {
$sql="";//sql 条件
$sql="select * from ".$table;
if($cons!="") {
if(is_array($cons)) {
$k=0;
foreach($cons as $key=>$val) {
if($k==0) {
$sql.="where '";
$sql.=$key;
$sql.="'='";
$sql.=$val."'";
}else {
$sql.="and '";
$sql.=$key;
$sql.="'='";
$sql.=$val."'";
}
$k++;
}
}else {
$sql.=" ここで ".$cons;
}
}
$sql;
を返す
}
/*************************************************** * ***************************
* $table: テーブル名
* $cons: 状態
* 戻り値:XML形式ファイル
************************************************ ***** *************************/
function toExtXml($table,$start="0",$limit="10",$cons="") {
$sql=$this->generateSql($table,$cons);
$totalNum=$this->findCount($sql);
$result=$this->findBySql($sql." LIMIT ".$start." ,".$limit);
$resultNum = count($result);//当前结果数
header("Content-Type: text/xml");
$xml='';
$xml.="";
$xml.="".$totalNum."";
$xml.="";
for($i=0;$i
$xml.="- ";
foreach($result[$i] as $key=>$val)
$xml.="<".$key.">".$val."".$key.">";
$xml.="";
}
$xml.="";
$xml.="";
$xml を返す;
}
/*************************************************** * ***************************
* $table: テーブル名
* $mapping: 配列形式のヘッダー情報 $map=array('No','Name','Email','Age');
* $fileName: WORDファイル名
* 戻り値: WORD形式ファイル
************************************************ ***** *************************/
function toWord($table,$mapping,$fileName) {
header('Content-type: application/doc');
header('Content-Disposition:attachment; filename="'.$fileName.'.doc"');
echo '
xmlns:w="urn:schemas-microsoft-com:office:word"
xmlns="[url=http://www.w3.org/TR/REC-html40]http://www.w3.org/TR/REC-html40[/url]">
<頭>
'.$fileName.'
';
echo'
';
if(is_array($mapping)) {
foreach($mapping as $key=>$val)
echo'
'.$val.' | ';
}
echo'
';
$results=$this->findBySql('select * from '.$table);
foreach($results as $result) {
echo'
';
foreach($result as $key=>$val)
echo'
'.$val.' | ';
echo'
';
}
echo'
';
echo'';
echo'